@opengis/cms 0.0.32 → 0.0.33
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.
- package/dist/index.js +6933 -6487
- package/dist/index.umd.cjs +51 -50
- package/package.json +3 -2
- package/server/routes/cms/controllers/deleteMedia.js +76 -76
- package/server/routes/cms/controllers/downloadMedia.js +49 -49
- package/server/routes/cms/controllers/getPermissions.js +15 -15
- package/server/routes/cms/controllers/insertContent.js +7 -7
- package/server/routes/cms/controllers/listMedia.js +94 -94
- package/server/routes/cms/controllers/metadataMedia.js +39 -39
- package/server/routes/cms/controllers/setPermissions.js +49 -49
- package/server/routes/cms/controllers/uploadMedia.js +79 -79
- package/server/templates/select/core.user_mentioned.sql +1 -1
|
@@ -1,50 +1,50 @@
|
|
|
1
|
-
import { logger, pgClients, dataInsert } from '@opengis/fastify-table/utils.js';
|
|
2
|
-
|
|
3
|
-
export default async function setPermissions(req, reply) {
|
|
4
|
-
const { pg = pgClients.client, params = {}, user = {}, body = {} } = req;
|
|
5
|
-
|
|
6
|
-
if (!user?.uid) {
|
|
7
|
-
return reply.status(401).send('unauthorized');
|
|
8
|
-
}
|
|
9
|
-
|
|
10
|
-
if (!params.id) {
|
|
11
|
-
return reply.status(400).send('not enough params: id');
|
|
12
|
-
}
|
|
13
|
-
|
|
14
|
-
const client = await pg.connect()
|
|
15
|
-
const result = {};
|
|
16
|
-
try {
|
|
17
|
-
await client.query('BEGIN');
|
|
18
|
-
|
|
19
|
-
const { rowCount = 0 } = await client.query(
|
|
20
|
-
`delete from site.permissions where user_id=$1`,
|
|
21
|
-
[params.id].filter(Boolean),
|
|
22
|
-
);
|
|
23
|
-
|
|
24
|
-
Object.assign(result, { deleted: rowCount });
|
|
25
|
-
|
|
26
|
-
if (Array.isArray(body.permissions) && body.permissions?.length) {
|
|
27
|
-
body.permissions.forEach((el) => {
|
|
28
|
-
Object.assign(el, { user_id: el.user_id || params.id });
|
|
29
|
-
});
|
|
30
|
-
|
|
31
|
-
await Promise.all(body.permissions.map(async (el) => dataInsert({
|
|
32
|
-
pg: client,
|
|
33
|
-
table: 'site.permissions',
|
|
34
|
-
data: el,
|
|
35
|
-
uid: user.uid,
|
|
36
|
-
})));
|
|
37
|
-
|
|
38
|
-
Object.assign(result, { inserted: body.permissions.length });
|
|
39
|
-
}
|
|
40
|
-
|
|
41
|
-
await client.query('COMMIT');
|
|
42
|
-
return reply.status(200).send(result);
|
|
43
|
-
} catch (err) {
|
|
44
|
-
await client.query('ROLLBACK');
|
|
45
|
-
logger.file('cms/permissions', { error: err.toString(), stack: err.stack });
|
|
46
|
-
return reply.status(500).send('set permissions error');
|
|
47
|
-
} finally {
|
|
48
|
-
client.release();
|
|
49
|
-
}
|
|
1
|
+
import { logger, pgClients, dataInsert } from '@opengis/fastify-table/utils.js';
|
|
2
|
+
|
|
3
|
+
export default async function setPermissions(req, reply) {
|
|
4
|
+
const { pg = pgClients.client, params = {}, user = {}, body = {} } = req;
|
|
5
|
+
|
|
6
|
+
if (!user?.uid) {
|
|
7
|
+
return reply.status(401).send('unauthorized');
|
|
8
|
+
}
|
|
9
|
+
|
|
10
|
+
if (!params.id) {
|
|
11
|
+
return reply.status(400).send('not enough params: id');
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
const client = await pg.connect()
|
|
15
|
+
const result = {};
|
|
16
|
+
try {
|
|
17
|
+
await client.query('BEGIN');
|
|
18
|
+
|
|
19
|
+
const { rowCount = 0 } = await client.query(
|
|
20
|
+
`delete from site.permissions where user_id=$1`,
|
|
21
|
+
[params.id].filter(Boolean),
|
|
22
|
+
);
|
|
23
|
+
|
|
24
|
+
Object.assign(result, { deleted: rowCount });
|
|
25
|
+
|
|
26
|
+
if (Array.isArray(body.permissions) && body.permissions?.length) {
|
|
27
|
+
body.permissions.forEach((el) => {
|
|
28
|
+
Object.assign(el, { user_id: el.user_id || params.id });
|
|
29
|
+
});
|
|
30
|
+
|
|
31
|
+
await Promise.all(body.permissions.map(async (el) => dataInsert({
|
|
32
|
+
pg: client,
|
|
33
|
+
table: 'site.permissions',
|
|
34
|
+
data: el,
|
|
35
|
+
uid: user.uid,
|
|
36
|
+
})));
|
|
37
|
+
|
|
38
|
+
Object.assign(result, { inserted: body.permissions.length });
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
await client.query('COMMIT');
|
|
42
|
+
return reply.status(200).send(result);
|
|
43
|
+
} catch (err) {
|
|
44
|
+
await client.query('ROLLBACK');
|
|
45
|
+
logger.file('cms/permissions', { error: err.toString(), stack: err.stack });
|
|
46
|
+
return reply.status(500).send('set permissions error');
|
|
47
|
+
} finally {
|
|
48
|
+
client.release();
|
|
49
|
+
}
|
|
50
50
|
}
|
|
@@ -1,80 +1,80 @@
|
|
|
1
|
-
import path from 'node:path';
|
|
2
|
-
import { mkdir } from 'node:fs/promises';
|
|
3
|
-
|
|
4
|
-
import { uploadMultiPart, config, getFolder, dataInsert, pgClients } from "@opengis/fastify-table/utils.js";
|
|
5
|
-
|
|
6
|
-
// path.resolve() converts POSIX paths from getFolder to valid Windows paths (Bun/Node fs require this on Windows)
|
|
7
|
-
const rootDir = path.resolve(getFolder(config, 'local'));
|
|
8
|
-
const dir = '/files';
|
|
9
|
-
|
|
10
|
-
export default async function uploadMedia(req, reply) {
|
|
11
|
-
const { pg = pgClients.client, user = {}, query = {} } = req;
|
|
12
|
-
|
|
13
|
-
if (!pg?.pk?.['site.media']) {
|
|
14
|
-
return reply.status(404).send('table not found');
|
|
15
|
-
}
|
|
16
|
-
|
|
17
|
-
if (query.subdir && (typeof query.subdir !== 'string' || query.subdir.includes('..'))) {
|
|
18
|
-
return reply.status(403).send('invalid query params: subdir');
|
|
19
|
-
}
|
|
20
|
-
|
|
21
|
-
// upload assets
|
|
22
|
-
if (req.headers['content-type']?.split?.(';')?.shift?.() === 'multipart/form-data') {
|
|
23
|
-
const file = await uploadMultiPart(req, { subdir: query.subdir || '', originalFilename: true }).catch(err => {
|
|
24
|
-
if (err.message === 'file with specified name already exists in directory') {
|
|
25
|
-
err.message = 'Файл з вказаною назвою вже існує';
|
|
26
|
-
err.statusCode = 400;
|
|
27
|
-
}
|
|
28
|
-
throw err;
|
|
29
|
-
});
|
|
30
|
-
|
|
31
|
-
const { originalFilename: filename, filetype, mimetype } = file;
|
|
32
|
-
const relpath = path.join(dir, query.subdir || '', file.originalFilename).replace(/\\/g, '/');
|
|
33
|
-
|
|
34
|
-
const id = await dataInsert({
|
|
35
|
-
pg,
|
|
36
|
-
table: 'site.media',
|
|
37
|
-
data: {
|
|
38
|
-
filename,
|
|
39
|
-
filetype,
|
|
40
|
-
subdir: query.subdir,
|
|
41
|
-
url: relpath,
|
|
42
|
-
mime: mimetype,
|
|
43
|
-
filesize: file.size,
|
|
44
|
-
},
|
|
45
|
-
uid: user?.uid,
|
|
46
|
-
}).then(el => el?.rows?.[0]?.media_id);
|
|
47
|
-
|
|
48
|
-
return reply.status(200).send({
|
|
49
|
-
res: 'ok',
|
|
50
|
-
name: filename,
|
|
51
|
-
type: 'file',
|
|
52
|
-
mimetype,
|
|
53
|
-
result: {
|
|
54
|
-
file_id: id,
|
|
55
|
-
format: file.extension,
|
|
56
|
-
size: file.size,
|
|
57
|
-
// entity_id: resultInsert?.entity_id,
|
|
58
|
-
file_path: relpath,
|
|
59
|
-
file_name: filename,
|
|
60
|
-
dir: path.dirname(relpath).replace(/\\/g, '/'),
|
|
61
|
-
native_file_name: filename,
|
|
62
|
-
},
|
|
63
|
-
});
|
|
64
|
-
}
|
|
65
|
-
|
|
66
|
-
if (!query.subdir) {
|
|
67
|
-
return reply.status(400).send('not enough query params: subdir');
|
|
68
|
-
}
|
|
69
|
-
|
|
70
|
-
// create directory
|
|
71
|
-
const relpath = path.join(dir, query.subdir).replace(/\\/g, '/');
|
|
72
|
-
const dirpath = path.join(rootDir, relpath);
|
|
73
|
-
await mkdir(dirpath, { recursive: true });
|
|
74
|
-
|
|
75
|
-
return reply.status(200).send({
|
|
76
|
-
relpath,
|
|
77
|
-
dirname: path.basename(query.subdir),
|
|
78
|
-
type: 'dir',
|
|
79
|
-
});
|
|
1
|
+
import path from 'node:path';
|
|
2
|
+
import { mkdir } from 'node:fs/promises';
|
|
3
|
+
|
|
4
|
+
import { uploadMultiPart, config, getFolder, dataInsert, pgClients } from "@opengis/fastify-table/utils.js";
|
|
5
|
+
|
|
6
|
+
// path.resolve() converts POSIX paths from getFolder to valid Windows paths (Bun/Node fs require this on Windows)
|
|
7
|
+
const rootDir = path.resolve(getFolder(config, 'local'));
|
|
8
|
+
const dir = '/files';
|
|
9
|
+
|
|
10
|
+
export default async function uploadMedia(req, reply) {
|
|
11
|
+
const { pg = pgClients.client, user = {}, query = {} } = req;
|
|
12
|
+
|
|
13
|
+
if (!pg?.pk?.['site.media']) {
|
|
14
|
+
return reply.status(404).send('table not found');
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
if (query.subdir && (typeof query.subdir !== 'string' || query.subdir.includes('..'))) {
|
|
18
|
+
return reply.status(403).send('invalid query params: subdir');
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
// upload assets
|
|
22
|
+
if (req.headers['content-type']?.split?.(';')?.shift?.() === 'multipart/form-data') {
|
|
23
|
+
const file = await uploadMultiPart(req, { subdir: query.subdir || '', originalFilename: true }).catch(err => {
|
|
24
|
+
if (err.message === 'file with specified name already exists in directory') {
|
|
25
|
+
err.message = 'Файл з вказаною назвою вже існує';
|
|
26
|
+
err.statusCode = 400;
|
|
27
|
+
}
|
|
28
|
+
throw err;
|
|
29
|
+
});
|
|
30
|
+
|
|
31
|
+
const { originalFilename: filename, filetype, mimetype } = file;
|
|
32
|
+
const relpath = path.join(dir, query.subdir || '', file.originalFilename).replace(/\\/g, '/');
|
|
33
|
+
|
|
34
|
+
const id = await dataInsert({
|
|
35
|
+
pg,
|
|
36
|
+
table: 'site.media',
|
|
37
|
+
data: {
|
|
38
|
+
filename,
|
|
39
|
+
filetype,
|
|
40
|
+
subdir: query.subdir,
|
|
41
|
+
url: relpath,
|
|
42
|
+
mime: mimetype,
|
|
43
|
+
filesize: file.size,
|
|
44
|
+
},
|
|
45
|
+
uid: user?.uid,
|
|
46
|
+
}).then(el => el?.rows?.[0]?.media_id);
|
|
47
|
+
|
|
48
|
+
return reply.status(200).send({
|
|
49
|
+
res: 'ok',
|
|
50
|
+
name: filename,
|
|
51
|
+
type: 'file',
|
|
52
|
+
mimetype,
|
|
53
|
+
result: {
|
|
54
|
+
file_id: id,
|
|
55
|
+
format: file.extension,
|
|
56
|
+
size: file.size,
|
|
57
|
+
// entity_id: resultInsert?.entity_id,
|
|
58
|
+
file_path: relpath,
|
|
59
|
+
file_name: filename,
|
|
60
|
+
dir: path.dirname(relpath).replace(/\\/g, '/'),
|
|
61
|
+
native_file_name: filename,
|
|
62
|
+
},
|
|
63
|
+
});
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
if (!query.subdir) {
|
|
67
|
+
return reply.status(400).send('not enough query params: subdir');
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
// create directory
|
|
71
|
+
const relpath = path.join(dir, query.subdir).replace(/\\/g, '/');
|
|
72
|
+
const dirpath = path.join(rootDir, relpath);
|
|
73
|
+
await mkdir(dirpath, { recursive: true });
|
|
74
|
+
|
|
75
|
+
return reply.status(200).send({
|
|
76
|
+
relpath,
|
|
77
|
+
dirname: path.basename(query.subdir),
|
|
78
|
+
type: 'dir',
|
|
79
|
+
});
|
|
80
80
|
}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
select uid, coalesce(sur_name,'')||coalesce(' '||user_name,'') as text, email from admin.users
|
|
1
|
+
select uid, coalesce(sur_name,'')||coalesce(' '||user_name,'') as text, email from admin.users
|
|
2
2
|
where enabled order by coalesce(sur_name,'')||coalesce(' '||user_name,'')
|