@vacantthinker/firefox-addon-framework-easy 2026.5.2204 → 2026.5.2206

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (3) hide show
  1. package/index.js +1 -0
  2. package/package.json +1 -1
  3. package/src/baseORM.js +228 -0
package/index.js CHANGED
@@ -1,3 +1,4 @@
1
1
  export * from './src/baseService.js'
2
2
  export * from './src/baseRuntimeSetup.js'
3
3
  export * from './src/baseOp.js'
4
+ export * from './src/baseORM.js'
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@vacantthinker/firefox-addon-framework-easy",
3
- "version": "2026.5.2204",
3
+ "version": "2026.5.2206",
4
4
  "description": "",
5
5
  "main": "index.js",
6
6
  "publishConfig": {
package/src/baseORM.js ADDED
@@ -0,0 +1,228 @@
1
+ import {stoOpCheck, stoOpGet, stoOpQuery_startsWith, stoOpRem, stoOpSet} from "./baseOp.js";
2
+
3
+
4
+ /**
5
+ * eg:
6
+ *
7
+ * "domain ://abcdefg.com":{
8
+ * "keyAAA": "valueBBB"
9
+ * }
10
+ */
11
+ export class BaseORM {
12
+ // Private class fields for encapsulation
13
+ #keyPrefix = `domain `;
14
+ #domainDefaultValue = {};
15
+
16
+ // Private helper method to generate the prefix key
17
+ #domainKey(k) {
18
+ return `${this.#keyPrefix}${k}`;
19
+ }
20
+
21
+ /**
22
+ * check domain exists, return true/false
23
+ * @param {string} domain
24
+ * @return {Promise<boolean>}
25
+ */
26
+ async #checkDomain(domain) {
27
+ return await stoOpCheck(this.#domainKey(domain));
28
+ }
29
+
30
+ /**
31
+ * @param {string} domain
32
+ * @return {Promise<void>}
33
+ */
34
+ async #addDomain(domain) {
35
+ await stoOpSet(this.#domainKey(domain), this.#domainDefaultValue);
36
+ }
37
+
38
+ /**
39
+ * @param {string} domain
40
+ * @return {Promise<void>}
41
+ */
42
+ async #removeDomain(domain) {
43
+ await stoOpRem(this.#domainKey(domain));
44
+ }
45
+
46
+ /**
47
+ * @param {string} domain
48
+ * @param {*} valueNew
49
+ * @return {Promise<void>}
50
+ */
51
+ async #updateDomain(domain, valueNew) {
52
+ await stoOpSet(this.#domainKey(domain), valueNew);
53
+ }
54
+
55
+ /**
56
+ * eg: ['a.com', 'b.com', 'c.com']
57
+ * @returns {Promise<string[]>}
58
+ */
59
+ async getALLDomainKey() {
60
+ // stoOpQueryByPrefix
61
+ let strings = await stoOpQuery_startsWith(this.#keyPrefix);
62
+ return strings.map(v => v.replaceAll(this.#keyPrefix, ''));
63
+ }
64
+
65
+ /**
66
+ * @returns {Promise<{domainList: string[], domainKeyValueMap: {}}>}
67
+ */
68
+ async getALLDomainMap() {
69
+ let domainList = await this.getALLDomainKey();
70
+
71
+ const domainKeyValueMap = {};
72
+ for (let domain of domainList) {
73
+ domainKeyValueMap[domain] = await this.getDomain(domain);
74
+ }
75
+
76
+ return {domainList, domainKeyValueMap};
77
+ }
78
+
79
+ /**
80
+ * @param {string} domain
81
+ * @returns {Promise<{}>}
82
+ */
83
+ async getDomain(domain) {
84
+ if (!(await this.#checkDomain(domain))) {
85
+ await this.#addDomain(domain);
86
+ }
87
+ return await stoOpGet(this.#domainKey(domain));
88
+ }
89
+
90
+ /**
91
+ * {a:a1} => {a:a222}
92
+ * @param {string} domain 'xxx.xxxxx.xxx'
93
+ * @param {string} key
94
+ * @param {string} valueToUpdate
95
+ * @return {Promise<{}>}
96
+ */
97
+ async updateDomainValueByOneKeyValue(domain, key, valueToUpdate) {
98
+ if (!(await this.#checkDomain(domain))) {
99
+ await this.#addDomain(domain);
100
+ }
101
+ let domainValueGet = await this.getDomain(domain);
102
+ domainValueGet[key] = valueToUpdate;
103
+ await this.#updateDomain(domain, domainValueGet);
104
+ return await this.getDomain(domain);
105
+ }
106
+
107
+ /**
108
+ * @param {string} domain 'xxx.xxxxx.xxx'
109
+ * @return {Promise<{}>}
110
+ */
111
+ async clearThisDomain(domain) {
112
+ let domainValue = await this.getDomain(domain);
113
+ await this.#removeDomain(domain);
114
+ return domainValue;
115
+ }
116
+ }
117
+
118
+ /**
119
+ * eg:
120
+ *
121
+ * "domain www.abcdefg.com":{
122
+ * "keyAAA": "valueBBB"
123
+ * }
124
+ *
125
+ * @returns {{getALLDomainKey: function(): Promise<string[]>, getALLDomainMap: function(): Promise<{domainList: *, domainKeyValueMap: {}}>, getDomain: function(string): Promise<{}>, updateDomainValueByOneKeyValue: function(string, string, string): Promise<{}>, clearThisDomain: function(*): Promise<{}>}}
126
+ */
127
+ export function baseORM() {
128
+
129
+ let keyPrefix = `domain `;
130
+ const domainKey = (k) => `${keyPrefix}${k}`;
131
+ const domainDefaultValue = {};
132
+
133
+ /**
134
+ * check domain exists, return true/false
135
+ * @param domain{string}
136
+ * @return {Promise<boolean>}
137
+ */
138
+ async function checkDomain(domain) {
139
+ return await stoOpCheck(domainKey(domain));
140
+ }
141
+
142
+ /**
143
+ * @param domain{string}
144
+ * @return {Promise<void>}
145
+ */
146
+ async function addDomain(domain) {
147
+ await stoOpSet(domainKey(domain), domainDefaultValue);
148
+ }
149
+
150
+ /**
151
+ * @param domain{string}
152
+ * @return {Promise<void>}
153
+ */
154
+ async function removeDomain(domain) {
155
+ await stoOpRem(domainKey(domain));
156
+ }
157
+
158
+ /**
159
+ * @param domain{string}
160
+ * @param valueNew
161
+ * @return {Promise<void>}
162
+ */
163
+ async function updateDomain(domain, valueNew) {
164
+ await stoOpSet(domainKey(domain), valueNew);
165
+ }
166
+
167
+ return {
168
+ /**
169
+ * eg: ['a.com', 'b.com', 'c.com']
170
+ * @returns {Promise<string[]>}
171
+ */
172
+ getALLDomainKey: async function () {
173
+ // stoOpQueryByPrefix
174
+ let strings = await stoOpQuery_startsWith(keyPrefix);
175
+ return strings.map(v => v.replaceAll(keyPrefix, ''));
176
+ },
177
+ getALLDomainMap: async function () {
178
+ let domainList = await this.getALLDomainKey();
179
+
180
+ // todo use for-loop not the reduce()!
181
+ const domainKeyValueMap = {}
182
+ for (let domain of domainList) {
183
+ domainKeyValueMap[domain] = await this.getDomain(domain)
184
+ }
185
+
186
+ return {domainList, domainKeyValueMap};
187
+ },
188
+
189
+ /**
190
+ *
191
+ * @param {string}domain
192
+ * @returns {Promise<{}>}
193
+ */
194
+ getDomain: async function (domain) {
195
+ if (!await checkDomain(domain)) {
196
+ await addDomain(domain);
197
+ }
198
+ return await stoOpGet(domainKey(domain));
199
+ },
200
+
201
+ /**
202
+ * {a:a1} => {a:a222}
203
+ * @param {string}domain 'xxx.xxxxx.xxx'
204
+ * @param{string}key
205
+ * @param {string}valueToUpdate
206
+ * @return {Promise<{}>}
207
+ */
208
+ updateDomainValueByOneKeyValue: async function (domain, key, valueToUpdate) {
209
+ if (!await checkDomain(domain)) {
210
+ await addDomain(domain);
211
+ }
212
+ let domainValueGet = await this.getDomain(domain);
213
+ domainValueGet[key] = valueToUpdate;
214
+ await updateDomain(domain, domainValueGet);
215
+ return (await this.getDomain(domain));
216
+ },
217
+
218
+ /**
219
+ * @param domain 'xxx.xxxxx.xxx'
220
+ * @return {Promise<{}>}
221
+ */
222
+ clearThisDomain: async function (domain) {
223
+ let domainValue = await this.getDomain(domain);
224
+ await removeDomain(domain);
225
+ return domainValue;
226
+ },
227
+ };
228
+ }