- validate all file-upload via clamdscan (clamav), throw ValidationException in case of an error
All checks were successful
CI Pipeline / japa-tests (push) Successful in 50s
All checks were successful
CI Pipeline / japa-tests (push) Successful in 50s
- add @types/clamscan and clamscan for node - package clamav-daemon and clamav-frehshclam for docker - add API Controller: HomeController.ts for /api/years and /api/sitelinks/{year} change root path of file storage from '/storage/app/public/files' to '/storage/app/public' - adapt dockerfile to use node:18-bookworm-slim
This commit is contained in:
parent
5f8fe1c16d
commit
b6b1c90ff8
52
Dockerfile
52
Dockerfile
|
@ -1,21 +1,52 @@
|
||||||
################## First Stage - Creating base #########################
|
################## First Stage - Creating base #########################
|
||||||
|
|
||||||
# Created a variable to hold our node base image
|
# Created a variable to hold our node base image
|
||||||
ARG NODE_IMAGE=node:18.14.2-alpine
|
ARG NODE_IMAGE=node:18-bookworm-slim
|
||||||
|
|
||||||
|
|
||||||
# Using the variable to create our base image
|
|
||||||
FROM $NODE_IMAGE AS base
|
FROM $NODE_IMAGE AS base
|
||||||
# Running a command to install dumb-init to handle processes
|
# Install dumb-init and ClamAV, and perform ClamAV database update
|
||||||
RUN apk --no-cache add dumb-init
|
RUN apt update \
|
||||||
# Creating folders and changing ownerships
|
&& apt-get install -y dumb-init clamav clamav-daemon nano \
|
||||||
RUN mkdir -p /home/node/app && chown node:node /home/node/app
|
&& rm -rf /var/lib/apt/lists/* \
|
||||||
|
# Creating folders and changing ownerships
|
||||||
|
&& mkdir -p /home/node/app && chown node:node /home/node/app \
|
||||||
|
&& mkdir -p /var/lib/clamav \
|
||||||
|
&& mkdir /usr/local/share/clamav \
|
||||||
|
&& chown -R node:clamav /var/lib/clamav /usr/local/share/clamav /etc/clamav
|
||||||
|
# -----------------------------------------------
|
||||||
|
# --- ClamAV & FeshClam -------------------------
|
||||||
|
# -----------------------------------------------
|
||||||
|
# RUN \
|
||||||
|
# chmod 644 /etc/clamav/freshclam.conf && \
|
||||||
|
# freshclam && \
|
||||||
|
# mkdir /var/run/clamav && \
|
||||||
|
# chown -R clamav:root /var/run/clamav
|
||||||
|
|
||||||
|
# # initial update of av databases
|
||||||
|
# RUN freshclam
|
||||||
|
|
||||||
|
# Configure Clam AV...
|
||||||
|
COPY --chown=node:clamav ./*.conf /etc/clamav/
|
||||||
|
|
||||||
|
# permissions
|
||||||
|
RUN mkdir /var/run/clamav && \
|
||||||
|
chown node:clamav /var/run/clamav && \
|
||||||
|
chmod 750 /var/run/clamav
|
||||||
# Setting the working directory
|
# Setting the working directory
|
||||||
WORKDIR /home/node/app
|
WORKDIR /home/node/app
|
||||||
# Changing the current active user to "node"
|
# Changing the current active user to "node"
|
||||||
USER node
|
USER node
|
||||||
# # Creating a new folder "tmp"
|
|
||||||
# RUN mkdir tmp
|
# initial update of av databases
|
||||||
|
RUN freshclam
|
||||||
|
|
||||||
|
VOLUME /var/lib/clamav
|
||||||
|
COPY --chown=node:clamav docker-entrypoint.sh /home/node/app/docker-entrypoint.sh
|
||||||
|
RUN chmod +x /home/node/app/docker-entrypoint.sh
|
||||||
|
ENV TZ="Europe/Vienna"
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
################## Second Stage - Installing dependencies ##########
|
################## Second Stage - Installing dependencies ##########
|
||||||
# In this stage, we will start installing dependencies
|
# In this stage, we will start installing dependencies
|
||||||
|
@ -31,7 +62,7 @@ COPY --chown=node:node . .
|
||||||
################## Third Stage - Building Stage #####################
|
################## Third Stage - Building Stage #####################
|
||||||
# In this stage, we will start building dependencies
|
# In this stage, we will start building dependencies
|
||||||
FROM dependencies AS build
|
FROM dependencies AS build
|
||||||
# We run "node ace build" to build the app for production
|
# We run "node ace build" to build the app (dist folder) for production
|
||||||
RUN node ace build --production
|
RUN node ace build --production
|
||||||
|
|
||||||
|
|
||||||
|
@ -51,5 +82,6 @@ RUN npm ci --omit=dev
|
||||||
COPY --chown=node:node --from=build /home/node/app/build .
|
COPY --chown=node:node --from=build /home/node/app/build .
|
||||||
# Expose port
|
# Expose port
|
||||||
EXPOSE $PORT
|
EXPOSE $PORT
|
||||||
|
ENTRYPOINT ["/home/node/app/docker-entrypoint.sh"]
|
||||||
# Run the command to start the server using "dumb-init"
|
# Run the command to start the server using "dumb-init"
|
||||||
CMD [ "dumb-init", "node", "server.js" ]
|
CMD [ "dumb-init", "node", "server.js" ]
|
|
@ -1,6 +1,7 @@
|
||||||
import type { HttpContextContract } from '@ioc:Adonis/Core/HttpContext';
|
import type { HttpContextContract } from '@ioc:Adonis/Core/HttpContext';
|
||||||
// import Person from 'App/Models/Person';
|
// import Person from 'App/Models/Person';
|
||||||
import Dataset from 'App/Models/Dataset';
|
import Dataset from 'App/Models/Dataset';
|
||||||
|
import { StatusCodes } from 'http-status-codes';
|
||||||
|
|
||||||
// node ace make:controller Author
|
// node ace make:controller Author
|
||||||
export default class DatasetController {
|
export default class DatasetController {
|
||||||
|
@ -12,4 +13,50 @@ export default class DatasetController {
|
||||||
|
|
||||||
return datasets;
|
return datasets;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public async findAll({ response }: HttpContextContract) {
|
||||||
|
try {
|
||||||
|
const datasets = await Dataset.query()
|
||||||
|
.where('server_state', 'published')
|
||||||
|
.orWhere('server_state', 'deleted')
|
||||||
|
.preload('descriptions') // Preload any relationships you need
|
||||||
|
.orderBy('server_date_published');
|
||||||
|
return response.status(StatusCodes.OK).json(datasets);
|
||||||
|
} catch (error) {
|
||||||
|
return response.status(500).json({
|
||||||
|
message: error.message || 'Some error occurred while retrieving datasets.',
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public async findOne({ params }: HttpContextContract) {
|
||||||
|
const datasets = await Dataset.query()
|
||||||
|
.where('publish_id', params.publish_id)
|
||||||
|
.preload('titles')
|
||||||
|
.preload('descriptions')
|
||||||
|
.preload('user')
|
||||||
|
.preload('authors', (builder) => {
|
||||||
|
builder.orderBy('pivot_sort_order', 'asc');
|
||||||
|
})
|
||||||
|
.preload('contributors', (builder) => {
|
||||||
|
builder.orderBy('pivot_sort_order', 'asc');
|
||||||
|
})
|
||||||
|
.preload('subjects')
|
||||||
|
.preload('coverage')
|
||||||
|
.preload('licenses')
|
||||||
|
.preload('references')
|
||||||
|
.preload('project')
|
||||||
|
.preload('referenced_by', (builder) => {
|
||||||
|
builder.preload('dataset', (builder) => {
|
||||||
|
builder.preload('identifier');
|
||||||
|
});
|
||||||
|
})
|
||||||
|
.preload('files', (builder) => {
|
||||||
|
builder.preload('hashvalues');
|
||||||
|
})
|
||||||
|
.preload('identifier')
|
||||||
|
.firstOrFail();
|
||||||
|
|
||||||
|
return datasets;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
64
app/Controllers/Http/Api/HomeController.ts
Normal file
64
app/Controllers/Http/Api/HomeController.ts
Normal file
|
@ -0,0 +1,64 @@
|
||||||
|
import type { HttpContextContract } from '@ioc:Adonis/Core/HttpContext';
|
||||||
|
import Database from '@ioc:Adonis/Lucid/Database';
|
||||||
|
import { StatusCodes } from 'http-status-codes';
|
||||||
|
|
||||||
|
export default class HomeController {
|
||||||
|
public async findDocumentsPerYear({ response, params }: HttpContextContract) {
|
||||||
|
const year = params.year;
|
||||||
|
const from = parseInt(year);
|
||||||
|
const serverState = 'published';
|
||||||
|
try {
|
||||||
|
// Database.raw(`date_part('year', server_date_published) as pub_year`)
|
||||||
|
// const datasets = await Dataset.query()
|
||||||
|
// .select(['id', 'publish_id', 'server_date_published', ])
|
||||||
|
// .where('server_state', serverState)
|
||||||
|
// .andWhereRaw(`date_part('year', server_date_published) = ?`, [from])
|
||||||
|
// .preload('titles')
|
||||||
|
// .preload('authors')
|
||||||
|
// .orderBy('server_date_published');
|
||||||
|
|
||||||
|
const datasets = await Database.from('documents as doc')
|
||||||
|
.select([
|
||||||
|
'publish_id',
|
||||||
|
'server_date_published',
|
||||||
|
Database.raw(`date_part('year', server_date_published) as pub_year`)
|
||||||
|
],
|
||||||
|
// Database
|
||||||
|
// .raw('select "ip_address" from "user_logins" where "users.id" = "user_logins.user_id" limit 1')
|
||||||
|
// .wrap('(', ')')
|
||||||
|
)
|
||||||
|
.where('server_state', serverState)
|
||||||
|
.innerJoin('link_documents_persons as ba', 'doc.id', 'ba.document_id')
|
||||||
|
.andWhereRaw(`date_part('year', server_date_published) = ?`, [from])
|
||||||
|
.orderBy('server_date_published');
|
||||||
|
|
||||||
|
return response.json(datasets);
|
||||||
|
} catch (error) {
|
||||||
|
return response.status(StatusCodes.INTERNAL_SERVER_ERROR).json({
|
||||||
|
message: error.message || 'Some error occurred while retrieving datasets.',
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public async findYears({ response }: HttpContextContract) {
|
||||||
|
const serverState = 'published';
|
||||||
|
// Use raw SQL queries to select all cars which belongs to the user
|
||||||
|
try {
|
||||||
|
const datasets = await Database.rawQuery(
|
||||||
|
'SELECT distinct EXTRACT(YEAR FROM server_date_published) as published_date FROM gba.documents WHERE server_state = ?',
|
||||||
|
[serverState],
|
||||||
|
);
|
||||||
|
|
||||||
|
// Pluck the ids of the cars
|
||||||
|
const years = datasets.rows.map((dataset) => dataset.published_date);
|
||||||
|
// check if the cars is returned
|
||||||
|
// if (years.length > 0) {
|
||||||
|
return response.status(StatusCodes.OK).json(years);
|
||||||
|
// }
|
||||||
|
} catch (error) {
|
||||||
|
return response.status(StatusCodes.INTERNAL_SERVER_ERROR).json({
|
||||||
|
message: 'An error occurred while retrieving the list of publication years from the Tethys repository.',
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -20,6 +20,10 @@ import CreateDatasetValidator from 'App/Validators/CreateDatasetValidator';
|
||||||
import { TitleTypes, DescriptionTypes, ContributorTypes, PersonNameTypes, ReferenceIdentifierTypes, RelationTypes } from 'Contracts/enums';
|
import { TitleTypes, DescriptionTypes, ContributorTypes, PersonNameTypes, ReferenceIdentifierTypes, RelationTypes } from 'Contracts/enums';
|
||||||
import type { ModelQueryBuilderContract } from '@ioc:Adonis/Lucid/Orm';
|
import type { ModelQueryBuilderContract } from '@ioc:Adonis/Lucid/Orm';
|
||||||
import DatasetReference from 'App/Models/DatasetReference';
|
import DatasetReference from 'App/Models/DatasetReference';
|
||||||
|
import { cuid } from '@ioc:Adonis/Core/Helpers';
|
||||||
|
import File from 'App/Models/File';
|
||||||
|
import ClamScan from 'clamscan';
|
||||||
|
import { ValidationException } from '@ioc:Adonis/Core/Validator';
|
||||||
|
|
||||||
export default class DatasetController {
|
export default class DatasetController {
|
||||||
public async index({ auth, request, inertia }: HttpContextContract) {
|
public async index({ auth, request, inertia }: HttpContextContract) {
|
||||||
|
@ -50,12 +54,11 @@ export default class DatasetController {
|
||||||
}
|
}
|
||||||
|
|
||||||
// const results = await Database
|
// const results = await Database
|
||||||
// .query()
|
// .query()
|
||||||
// .select(Database.raw("CONCAT('https://doi.org/', b.value) AS concatenated_value"))
|
// .select(Database.raw("CONCAT('https://doi.org/', b.value) AS concatenated_value"))
|
||||||
// .from('documents as doc')
|
// .from('documents as doc')
|
||||||
// .innerJoin('dataset_identifiers as b', 'doc.id', 'b.dataset_id')
|
// .innerJoin('dataset_identifiers as b', 'doc.id', 'b.dataset_id')
|
||||||
// .groupBy('a.id').toQuery();
|
// .groupBy('a.id').toQuery();
|
||||||
|
|
||||||
|
|
||||||
// const users = await User.query().orderBy('login').paginate(page, limit);
|
// const users = await User.query().orderBy('login').paginate(page, limit);
|
||||||
const myDatasets = await datasets
|
const myDatasets = await datasets
|
||||||
|
@ -91,7 +94,7 @@ export default class DatasetController {
|
||||||
}
|
}
|
||||||
|
|
||||||
public async create({ inertia }: HttpContextContract) {
|
public async create({ inertia }: HttpContextContract) {
|
||||||
const licenses = await License.query().select('id', 'name_long').pluck('name_long', 'id');
|
const licenses = await License.query().select('id', 'name_long').where('active', 'true').pluck('name_long', 'id');
|
||||||
|
|
||||||
const projects = await Project.query().pluck('label', 'id');
|
const projects = await Project.query().pluck('label', 'id');
|
||||||
|
|
||||||
|
@ -103,6 +106,7 @@ export default class DatasetController {
|
||||||
gis: 'GIS',
|
gis: 'GIS',
|
||||||
models: 'Models',
|
models: 'Models',
|
||||||
mixedtype: 'Mixed Type',
|
mixedtype: 'Mixed Type',
|
||||||
|
vocabulary: 'Vocabulary'
|
||||||
};
|
};
|
||||||
|
|
||||||
// const titletypes = {
|
// const titletypes = {
|
||||||
|
@ -313,33 +317,10 @@ export default class DatasetController {
|
||||||
await trx.rollback();
|
await trx.rollback();
|
||||||
}
|
}
|
||||||
console.error('Failed to create dataset and related models:', error);
|
console.error('Failed to create dataset and related models:', error);
|
||||||
|
// throw new ValidationException(true, { 'upload error': `failed to create dataset and related models. ${error}` });
|
||||||
// Handle the error and exit the controller code accordingly
|
|
||||||
// session.flash('message', 'Failed to create dataset and relaed models');
|
|
||||||
// return response.redirect().back();
|
|
||||||
throw error;
|
throw error;
|
||||||
}
|
}
|
||||||
|
|
||||||
// save data files:
|
|
||||||
const coverImage = request.files('files')[0];
|
|
||||||
if (coverImage) {
|
|
||||||
// clientName: 'Gehaltsschema.png'
|
|
||||||
// extname: 'png'
|
|
||||||
// fieldName: 'file'
|
|
||||||
// size: 135624
|
|
||||||
|
|
||||||
// await coverImage.moveToDisk('./')
|
|
||||||
await coverImage.moveToDisk(
|
|
||||||
'/test_dataset2',
|
|
||||||
{
|
|
||||||
name: 'renamed-file-name.jpg',
|
|
||||||
overwrite: true, // overwrite in case of conflict
|
|
||||||
},
|
|
||||||
'local',
|
|
||||||
);
|
|
||||||
// let path = coverImage.filePath;
|
|
||||||
}
|
|
||||||
|
|
||||||
session.flash('message', 'Dataset has been created successfully');
|
session.flash('message', 'Dataset has been created successfully');
|
||||||
// return response.redirect().toRoute('user.index');
|
// return response.redirect().toRoute('user.index');
|
||||||
return response.redirect().back();
|
return response.redirect().back();
|
||||||
|
@ -424,6 +405,80 @@ export default class DatasetController {
|
||||||
// await coverage.dataset().associate(dataset).save();
|
// await coverage.dataset().associate(dataset).save();
|
||||||
// await coverage.useTransaction(trx).related('dataset').associate(dataset);
|
// await coverage.useTransaction(trx).related('dataset').associate(dataset);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// save data files
|
||||||
|
const uploadedFiles = request.files('files');
|
||||||
|
for (const [index, file] of uploadedFiles.entries()) {
|
||||||
|
try {
|
||||||
|
await this.scanFileForViruses(file.tmpPath); //, 'gitea.lan', 3310);
|
||||||
|
// await this.scanFileForViruses("/tmp/testfile.txt");
|
||||||
|
} catch (error) {
|
||||||
|
// If the file is infected or there's an error scanning the file, throw a validation exception
|
||||||
|
throw error;
|
||||||
|
}
|
||||||
|
// clientName: 'Gehaltsschema.png'
|
||||||
|
// extname: 'png'
|
||||||
|
// fieldName: 'file'
|
||||||
|
const fileName = `file-${cuid()}.${file.extname}`;
|
||||||
|
const mimeType = file.headers['content-type'] || 'application/octet-stream'; // Fallback to a default MIME type
|
||||||
|
const datasetFolder = `files/${dataset.id}`;
|
||||||
|
// const size = file.size;
|
||||||
|
await file.moveToDisk(
|
||||||
|
datasetFolder,
|
||||||
|
{
|
||||||
|
name: fileName,
|
||||||
|
overwrite: true, // overwrite in case of conflict
|
||||||
|
},
|
||||||
|
'local',
|
||||||
|
);
|
||||||
|
// save file metadata into db
|
||||||
|
const newFile = new File();
|
||||||
|
newFile.pathName = `${datasetFolder}/${fileName}`;
|
||||||
|
newFile.fileSize = file.size;
|
||||||
|
newFile.mimeType = mimeType;
|
||||||
|
newFile.label = file.clientName;
|
||||||
|
newFile.sortOrder = index;
|
||||||
|
newFile.visibleInFrontdoor = true;
|
||||||
|
newFile.visibleInOai = true;
|
||||||
|
// let path = coverImage.filePath;
|
||||||
|
await dataset.useTransaction(trx).related('files').save(newFile);
|
||||||
|
// await newFile.createHashValues();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private async scanFileForViruses(filePath, host?: string, port?: number): Promise<void> {
|
||||||
|
// const clamscan = await (new ClamScan().init());
|
||||||
|
const opts: ClamScan.Options = {
|
||||||
|
removeInfected: true, // If true, removes infected files
|
||||||
|
debugMode: false, // Whether or not to log info/debug/error msgs to the console
|
||||||
|
scanRecursively: true, // If true, deep scan folders recursively
|
||||||
|
clamdscan: {
|
||||||
|
active: true, // If true, this module will consider using the clamdscan binary
|
||||||
|
host,
|
||||||
|
port,
|
||||||
|
multiscan: true, // Scan using all available cores! Yay!
|
||||||
|
},
|
||||||
|
preference: 'clamdscan', // If clamdscan is found and active, it will be used by default
|
||||||
|
};
|
||||||
|
|
||||||
|
return new Promise(async (resolve, reject) => {
|
||||||
|
try {
|
||||||
|
const clamscan = await new ClamScan().init(opts);
|
||||||
|
// You can re-use the `clamscan` object as many times as you want
|
||||||
|
// const version = await clamscan.getVersion();
|
||||||
|
// console.log(`ClamAV Version: ${version}`);
|
||||||
|
const { file, isInfected, viruses } = await clamscan.isInfected(filePath);
|
||||||
|
if (isInfected) {
|
||||||
|
console.log(`${file} is infected with ${viruses}!`);
|
||||||
|
reject(new ValidationException(true, { 'upload error': `File ${file} is infected!` }));
|
||||||
|
} else {
|
||||||
|
resolve();
|
||||||
|
}
|
||||||
|
} catch (error) {
|
||||||
|
// If there's an error scanning the file, throw a validation exception
|
||||||
|
reject(new ValidationException(true, { 'upload error': `${error.message}` }));
|
||||||
|
}
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
private async savePersons(dataset: Dataset, persons: any[], role: string, trx: TransactionClientContract) {
|
private async savePersons(dataset: Dataset, persons: any[], role: string, trx: TransactionClientContract) {
|
||||||
|
@ -459,8 +514,8 @@ export default class DatasetController {
|
||||||
'required': '{{ field }} is required',
|
'required': '{{ field }} is required',
|
||||||
'unique': '{{ field }} must be unique, and this value is already taken',
|
'unique': '{{ field }} must be unique, and this value is already taken',
|
||||||
// 'confirmed': '{{ field }} is not correct',
|
// 'confirmed': '{{ field }} is not correct',
|
||||||
'licences.minLength': 'at least {{ options.minLength }} permission must be defined',
|
'licenses.minLength': 'at least {{ options.minLength }} permission must be defined',
|
||||||
'licences.*.number': 'Define roles as valid numbers',
|
'licenses.*.number': 'Define roles as valid numbers',
|
||||||
'rights.equalTo': 'you must agree to continue',
|
'rights.equalTo': 'you must agree to continue',
|
||||||
|
|
||||||
'titles.0.value.minLength': 'Main Title must be at least {{ options.minLength }} characters long',
|
'titles.0.value.minLength': 'Main Title must be at least {{ options.minLength }} characters long',
|
||||||
|
|
|
@ -22,9 +22,10 @@ import License from './License';
|
||||||
import Subject from './Subject';
|
import Subject from './Subject';
|
||||||
import File from './File';
|
import File from './File';
|
||||||
import Coverage from './Coverage';
|
import Coverage from './Coverage';
|
||||||
import DatasetReference from './DatasetReference';
|
import DatasetReference from './DatasetReference';
|
||||||
import Collection from './Collection';
|
import Collection from './Collection';
|
||||||
import DatasetIdentifier from './DatasetIdentifier';
|
import DatasetIdentifier from './DatasetIdentifier';
|
||||||
|
import Project from './Project';
|
||||||
|
|
||||||
export default class Dataset extends BaseModel {
|
export default class Dataset extends BaseModel {
|
||||||
public static namingStrategy = new SnakeCaseNamingStrategy();
|
public static namingStrategy = new SnakeCaseNamingStrategy();
|
||||||
|
@ -53,6 +54,12 @@ export default class Dataset extends BaseModel {
|
||||||
@column({})
|
@column({})
|
||||||
public language: string;
|
public language: string;
|
||||||
|
|
||||||
|
@column({})
|
||||||
|
public publish_id: number | null = null;
|
||||||
|
|
||||||
|
@column({})
|
||||||
|
public project_id: number | null = null;
|
||||||
|
|
||||||
@column({})
|
@column({})
|
||||||
public account_id: number | null = null;
|
public account_id: number | null = null;
|
||||||
|
|
||||||
|
@ -62,7 +69,6 @@ export default class Dataset extends BaseModel {
|
||||||
@column({})
|
@column({})
|
||||||
public reviewer_id: number | null = null;
|
public reviewer_id: number | null = null;
|
||||||
|
|
||||||
|
|
||||||
@column({})
|
@column({})
|
||||||
public reject_editor_note: string | null;
|
public reject_editor_note: string | null;
|
||||||
|
|
||||||
|
@ -107,6 +113,11 @@ export default class Dataset extends BaseModel {
|
||||||
})
|
})
|
||||||
public user: BelongsTo<typeof User>;
|
public user: BelongsTo<typeof User>;
|
||||||
|
|
||||||
|
@belongsTo(() => Project, {
|
||||||
|
foreignKey: 'project_id',
|
||||||
|
})
|
||||||
|
public project: BelongsTo<typeof Project>;
|
||||||
|
|
||||||
@hasMany(() => Title, {
|
@hasMany(() => Title, {
|
||||||
foreignKey: 'document_id',
|
foreignKey: 'document_id',
|
||||||
})
|
})
|
||||||
|
@ -146,11 +157,15 @@ export default class Dataset extends BaseModel {
|
||||||
})
|
})
|
||||||
public references: HasMany<typeof DatasetReference>;
|
public references: HasMany<typeof DatasetReference>;
|
||||||
|
|
||||||
// public function collections()
|
// Dataset.hasMany(Reference, {
|
||||||
// {
|
// foreignKey: "related_document_id",
|
||||||
// return $this
|
// as: "referenced_by",
|
||||||
// ->belongsToMany(Collection::class, 'link_documents_collections', 'document_id', 'collection_id');
|
// });
|
||||||
// }
|
@hasMany(() => DatasetReference, {
|
||||||
|
foreignKey: 'related_document_id',
|
||||||
|
})
|
||||||
|
public referenced_by: HasMany<typeof DatasetReference>;
|
||||||
|
|
||||||
@manyToMany(() => Collection, {
|
@manyToMany(() => Collection, {
|
||||||
pivotForeignKey: 'document_id',
|
pivotForeignKey: 'document_id',
|
||||||
pivotRelatedForeignKey: 'collection_id',
|
pivotRelatedForeignKey: 'collection_id',
|
||||||
|
@ -159,11 +174,10 @@ export default class Dataset extends BaseModel {
|
||||||
public collections: ManyToMany<typeof Collection>;
|
public collections: ManyToMany<typeof Collection>;
|
||||||
|
|
||||||
@hasOne(() => DatasetIdentifier, {
|
@hasOne(() => DatasetIdentifier, {
|
||||||
foreignKey: 'document_id',
|
foreignKey: 'dataset_id',
|
||||||
})
|
})
|
||||||
public identifier: HasOne<typeof DatasetIdentifier>;
|
public identifier: HasOne<typeof DatasetIdentifier>;
|
||||||
|
|
||||||
|
|
||||||
@computed({
|
@computed({
|
||||||
serializeAs: 'main_title',
|
serializeAs: 'main_title',
|
||||||
})
|
})
|
||||||
|
@ -172,4 +186,26 @@ export default class Dataset extends BaseModel {
|
||||||
const mainTitle = this.titles?.find((title) => title.type === 'Main');
|
const mainTitle = this.titles?.find((title) => title.type === 'Main');
|
||||||
return mainTitle ? mainTitle.value : null;
|
return mainTitle ? mainTitle.value : null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@manyToMany(() => Person, {
|
||||||
|
pivotForeignKey: 'document_id',
|
||||||
|
pivotRelatedForeignKey: 'person_id',
|
||||||
|
pivotTable: 'link_documents_persons',
|
||||||
|
pivotColumns: ['role', 'sort_order', 'allow_email_contact'],
|
||||||
|
onQuery(query) {
|
||||||
|
query.wherePivot('role', 'author');
|
||||||
|
},
|
||||||
|
})
|
||||||
|
public authors: ManyToMany<typeof Person>;
|
||||||
|
|
||||||
|
@manyToMany(() => Person, {
|
||||||
|
pivotForeignKey: 'document_id',
|
||||||
|
pivotRelatedForeignKey: 'person_id',
|
||||||
|
pivotTable: 'link_documents_persons',
|
||||||
|
pivotColumns: ['role', 'sort_order', 'allow_email_contact'],
|
||||||
|
onQuery(query) {
|
||||||
|
query.wherePivot('role', 'contributor');
|
||||||
|
},
|
||||||
|
})
|
||||||
|
public contributors: ManyToMany<typeof Person>;
|
||||||
}
|
}
|
||||||
|
|
|
@ -14,7 +14,7 @@ export default class DatasetIdentifier extends BaseModel {
|
||||||
public id: number;
|
public id: number;
|
||||||
|
|
||||||
@column({})
|
@column({})
|
||||||
public document_id: number;
|
public dataset_id: number;
|
||||||
|
|
||||||
@column({})
|
@column({})
|
||||||
public type: string;
|
public type: string;
|
||||||
|
@ -34,7 +34,7 @@ export default class DatasetIdentifier extends BaseModel {
|
||||||
public updated_at?: DateTime;
|
public updated_at?: DateTime;
|
||||||
|
|
||||||
@belongsTo(() => Dataset, {
|
@belongsTo(() => Dataset, {
|
||||||
foreignKey: 'document_id',
|
foreignKey: 'dataset_id',
|
||||||
})
|
})
|
||||||
public dataset: BelongsTo<typeof Dataset>;
|
public dataset: BelongsTo<typeof Dataset>;
|
||||||
}
|
}
|
||||||
|
|
|
@ -46,4 +46,16 @@ export default class DatasetReference extends BaseModel {
|
||||||
foreignKey: 'document_id',
|
foreignKey: 'document_id',
|
||||||
})
|
})
|
||||||
public dataset: BelongsTo<typeof Dataset>;
|
public dataset: BelongsTo<typeof Dataset>;
|
||||||
|
|
||||||
|
// Reference.belongsTo(Dataset, {
|
||||||
|
// foreignKey: "related_document_id",
|
||||||
|
// as: "new_dataset",
|
||||||
|
// include: "identifier"
|
||||||
|
// });
|
||||||
|
@belongsTo(() => Dataset, {
|
||||||
|
foreignKey: 'related_document_id',
|
||||||
|
})
|
||||||
|
public new_dataset: BelongsTo<typeof Dataset>;
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -37,17 +37,20 @@ export default class File extends BaseModel {
|
||||||
public comment: string;
|
public comment: string;
|
||||||
|
|
||||||
@column()
|
@column()
|
||||||
public mimetype: string;
|
public mimeType: string;
|
||||||
|
|
||||||
@column()
|
@column()
|
||||||
public language: string;
|
public language: string;
|
||||||
|
|
||||||
@column()
|
@column()
|
||||||
public fileSize: bigint;
|
public fileSize: number;
|
||||||
|
|
||||||
@column()
|
@column()
|
||||||
public visibleInOai: boolean;
|
public visibleInOai: boolean;
|
||||||
|
|
||||||
|
@column()
|
||||||
|
public visibleInFrontdoor: boolean;
|
||||||
|
|
||||||
@column()
|
@column()
|
||||||
public sortOrder: number;
|
public sortOrder: number;
|
||||||
|
|
||||||
|
|
|
@ -129,8 +129,8 @@ export default class CreateDatasetValidator {
|
||||||
'required': '{{ field }} is required',
|
'required': '{{ field }} is required',
|
||||||
'unique': '{{ field }} must be unique, and this value is already taken',
|
'unique': '{{ field }} must be unique, and this value is already taken',
|
||||||
// 'confirmed': '{{ field }} is not correct',
|
// 'confirmed': '{{ field }} is not correct',
|
||||||
'licences.minLength': 'at least {{ options.minLength }} permission must be defined',
|
'licenses.minLength': 'at least {{ options.minLength }} permission must be defined',
|
||||||
'licences.*.number': 'Define roles as valid numbers',
|
'licenses.*.number': 'Define roles as valid numbers',
|
||||||
'rights.equalTo': 'you must agree to continue',
|
'rights.equalTo': 'you must agree to continue',
|
||||||
|
|
||||||
'titles.0.value.minLength': 'Main Title must be at least {{ options.minLength }} characters long',
|
'titles.0.value.minLength': 'Main Title must be at least {{ options.minLength }} characters long',
|
||||||
|
|
11
clamd.conf
Normal file
11
clamd.conf
Normal file
|
@ -0,0 +1,11 @@
|
||||||
|
# LogFile /dev/stdout
|
||||||
|
LogTime yes
|
||||||
|
LogClean yes
|
||||||
|
LogSyslog no
|
||||||
|
LogVerbose yes
|
||||||
|
DatabaseDirectory /var/lib/clamav
|
||||||
|
LocalSocket /var/run/clamav/clamd.socket
|
||||||
|
Foreground no
|
||||||
|
PidFile /var/run/clamav/clamd.pid
|
||||||
|
LocalSocketGroup node
|
||||||
|
User node
|
|
@ -54,7 +54,7 @@ export default driveConfig({
|
||||||
|
|
|
|
||||||
*/
|
*/
|
||||||
// root: Application.tmpPath('uploads'),
|
// root: Application.tmpPath('uploads'),
|
||||||
root: '/storage/app/public/files',
|
root: '/storage/app/public',
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|--------------------------------------------------------------------------
|
|--------------------------------------------------------------------------
|
||||||
|
|
47
docker-entrypoint.sh
Normal file
47
docker-entrypoint.sh
Normal file
|
@ -0,0 +1,47 @@
|
||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# # Run freshclam to update virus definitions
|
||||||
|
# freshclam
|
||||||
|
|
||||||
|
# # Sleep for a few seconds to give ClamAV time to start
|
||||||
|
# sleep 5
|
||||||
|
|
||||||
|
# # Start the ClamAV daemon
|
||||||
|
# /etc/init.d/clamav-daemon start
|
||||||
|
|
||||||
|
# bootstrap clam av service and clam av database updater
|
||||||
|
set -m
|
||||||
|
|
||||||
|
function process_file() {
|
||||||
|
if [[ ! -z "$1" ]]; then
|
||||||
|
local SETTING_LIST=$(echo "$1" | tr ',' '\n' | grep "^[A-Za-z][A-Za-z]*=.*$")
|
||||||
|
local SETTING
|
||||||
|
|
||||||
|
for SETTING in ${SETTING_LIST}; do
|
||||||
|
# Remove any existing copies of this setting. We do this here so that
|
||||||
|
# settings with multiple values (e.g. ExtraDatabase) can still be added
|
||||||
|
# multiple times below
|
||||||
|
local KEY=${SETTING%%=*}
|
||||||
|
sed -i $2 -e "/^${KEY} /d"
|
||||||
|
done
|
||||||
|
|
||||||
|
for SETTING in ${SETTING_LIST}; do
|
||||||
|
# Split on first '='
|
||||||
|
local KEY=${SETTING%%=*}
|
||||||
|
local VALUE=${SETTING#*=}
|
||||||
|
echo "${KEY} ${VALUE}" >> "$2"
|
||||||
|
done
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
# process_file "${CLAMD_SETTINGS_CSV}" /etc/clamav/clamd.conf
|
||||||
|
# process_file "${FRESHCLAM_SETTINGS_CSV}" /etc/clamav/freshclam.conf
|
||||||
|
|
||||||
|
# start in background
|
||||||
|
freshclam -d &
|
||||||
|
# /etc/init.d/clamav-freshclam start &
|
||||||
|
clamd
|
||||||
|
# /etc/init.d/clamav-daemon start &
|
||||||
|
|
||||||
|
# change back to CMD of dockerfile
|
||||||
|
exec "$@"
|
229
freshclam.conf
Normal file
229
freshclam.conf
Normal file
|
@ -0,0 +1,229 @@
|
||||||
|
##
|
||||||
|
## Example config file for freshclam
|
||||||
|
## Please read the freshclam.conf(5) manual before editing this file.
|
||||||
|
##
|
||||||
|
|
||||||
|
|
||||||
|
# Comment or remove the line below.
|
||||||
|
|
||||||
|
# Path to the database directory.
|
||||||
|
# WARNING: It must match clamd.conf's directive!
|
||||||
|
# Default: hardcoded (depends on installation options)
|
||||||
|
DatabaseDirectory /var/lib/clamav
|
||||||
|
|
||||||
|
# Path to the log file (make sure it has proper permissions)
|
||||||
|
# Default: disabled
|
||||||
|
# UpdateLogFile /dev/stdout
|
||||||
|
|
||||||
|
# Maximum size of the log file.
|
||||||
|
# Value of 0 disables the limit.
|
||||||
|
# You may use 'M' or 'm' for megabytes (1M = 1m = 1048576 bytes)
|
||||||
|
# and 'K' or 'k' for kilobytes (1K = 1k = 1024 bytes).
|
||||||
|
# in bytes just don't use modifiers. If LogFileMaxSize is enabled,
|
||||||
|
# log rotation (the LogRotate option) will always be enabled.
|
||||||
|
# Default: 1M
|
||||||
|
#LogFileMaxSize 2M
|
||||||
|
|
||||||
|
# Log time with each message.
|
||||||
|
# Default: no
|
||||||
|
LogTime yes
|
||||||
|
|
||||||
|
# Enable verbose logging.
|
||||||
|
# Default: no
|
||||||
|
LogVerbose yes
|
||||||
|
|
||||||
|
# Use system logger (can work together with UpdateLogFile).
|
||||||
|
# Default: no
|
||||||
|
LogSyslog no
|
||||||
|
|
||||||
|
# Specify the type of syslog messages - please refer to 'man syslog'
|
||||||
|
# for facility names.
|
||||||
|
# Default: LOG_LOCAL6
|
||||||
|
#LogFacility LOG_MAIL
|
||||||
|
|
||||||
|
# Enable log rotation. Always enabled when LogFileMaxSize is enabled.
|
||||||
|
# Default: no
|
||||||
|
#LogRotate yes
|
||||||
|
|
||||||
|
# This option allows you to save the process identifier of the daemon
|
||||||
|
# Default: disabled
|
||||||
|
#PidFile /var/run/freshclam.pid
|
||||||
|
PidFile /var/run/clamav/freshclam.pid
|
||||||
|
|
||||||
|
# By default when started freshclam drops privileges and switches to the
|
||||||
|
# "clamav" user. This directive allows you to change the database owner.
|
||||||
|
# Default: clamav (may depend on installation options)
|
||||||
|
DatabaseOwner node
|
||||||
|
|
||||||
|
# Use DNS to verify virus database version. Freshclam uses DNS TXT records
|
||||||
|
# to verify database and software versions. With this directive you can change
|
||||||
|
# the database verification domain.
|
||||||
|
# WARNING: Do not touch it unless you're configuring freshclam to use your
|
||||||
|
# own database verification domain.
|
||||||
|
# Default: current.cvd.clamav.net
|
||||||
|
#DNSDatabaseInfo current.cvd.clamav.net
|
||||||
|
|
||||||
|
# Uncomment the following line and replace XY with your country
|
||||||
|
# code. See http://www.iana.org/cctld/cctld-whois.htm for the full list.
|
||||||
|
# You can use db.XY.ipv6.clamav.net for IPv6 connections.
|
||||||
|
DatabaseMirror db.at.clamav.net
|
||||||
|
|
||||||
|
# database.clamav.net is a round-robin record which points to our most
|
||||||
|
# reliable mirrors. It's used as a fall back in case db.XY.clamav.net is
|
||||||
|
# not working. DO NOT TOUCH the following line unless you know what you
|
||||||
|
# are doing.
|
||||||
|
DatabaseMirror database.clamav.net
|
||||||
|
|
||||||
|
# How many attempts to make before giving up.
|
||||||
|
# Default: 3 (per mirror)
|
||||||
|
#MaxAttempts 5
|
||||||
|
|
||||||
|
# With this option you can control scripted updates. It's highly recommended
|
||||||
|
# to keep it enabled.
|
||||||
|
# Default: yes
|
||||||
|
#ScriptedUpdates yes
|
||||||
|
|
||||||
|
# By default freshclam will keep the local databases (.cld) uncompressed to
|
||||||
|
# make their handling faster. With this option you can enable the compression;
|
||||||
|
# the change will take effect with the next database update.
|
||||||
|
# Default: no
|
||||||
|
#CompressLocalDatabase no
|
||||||
|
|
||||||
|
# With this option you can provide custom sources (http:// or file://) for
|
||||||
|
# database files. This option can be used multiple times.
|
||||||
|
# Default: no custom URLs
|
||||||
|
#DatabaseCustomURL http://myserver.com/mysigs.ndb
|
||||||
|
#DatabaseCustomURL file:///mnt/nfs/local.hdb
|
||||||
|
|
||||||
|
# This option allows you to easily point freshclam to private mirrors.
|
||||||
|
# If PrivateMirror is set, freshclam does not attempt to use DNS
|
||||||
|
# to determine whether its databases are out-of-date, instead it will
|
||||||
|
# use the If-Modified-Since request or directly check the headers of the
|
||||||
|
# remote database files. For each database, freshclam first attempts
|
||||||
|
# to download the CLD file. If that fails, it tries to download the
|
||||||
|
# CVD file. This option overrides DatabaseMirror, DNSDatabaseInfo
|
||||||
|
# and ScriptedUpdates. It can be used multiple times to provide
|
||||||
|
# fall-back mirrors.
|
||||||
|
# Default: disabled
|
||||||
|
#PrivateMirror mirror1.mynetwork.com
|
||||||
|
#PrivateMirror mirror2.mynetwork.com
|
||||||
|
|
||||||
|
# Number of database checks per day.
|
||||||
|
# Default: 12 (every two hours)
|
||||||
|
#Checks 24
|
||||||
|
|
||||||
|
# Proxy settings
|
||||||
|
# Default: disabled
|
||||||
|
#HTTPProxyServer myproxy.com
|
||||||
|
#HTTPProxyPort 1234
|
||||||
|
#HTTPProxyUsername myusername
|
||||||
|
#HTTPProxyPassword mypass
|
||||||
|
|
||||||
|
# If your servers are behind a firewall/proxy which applies User-Agent
|
||||||
|
# filtering you can use this option to force the use of a different
|
||||||
|
# User-Agent header.
|
||||||
|
# Default: clamav/version_number
|
||||||
|
#HTTPUserAgent SomeUserAgentIdString
|
||||||
|
|
||||||
|
# Use aaa.bbb.ccc.ddd as client address for downloading databases. Useful for
|
||||||
|
# multi-homed systems.
|
||||||
|
# Default: Use OS'es default outgoing IP address.
|
||||||
|
#LocalIPAddress aaa.bbb.ccc.ddd
|
||||||
|
|
||||||
|
# Send the RELOAD command to clamd.
|
||||||
|
# Default: no
|
||||||
|
#NotifyClamd /path/to/clamd.conf
|
||||||
|
|
||||||
|
# Run command after successful database update.
|
||||||
|
# Default: disabled
|
||||||
|
#OnUpdateExecute command
|
||||||
|
|
||||||
|
# Run command when database update process fails.
|
||||||
|
# Default: disabled
|
||||||
|
#OnErrorExecute command
|
||||||
|
|
||||||
|
# Run command when freshclam reports outdated version.
|
||||||
|
# In the command string %v will be replaced by the new version number.
|
||||||
|
# Default: disabled
|
||||||
|
#OnOutdatedExecute command
|
||||||
|
|
||||||
|
# Don't fork into background.
|
||||||
|
# Default: no
|
||||||
|
Foreground no
|
||||||
|
|
||||||
|
# Enable debug messages in libclamav.
|
||||||
|
# Default: no
|
||||||
|
#Debug yes
|
||||||
|
|
||||||
|
# Timeout in seconds when connecting to database server.
|
||||||
|
# Default: 30
|
||||||
|
#ConnectTimeout 60
|
||||||
|
|
||||||
|
# Timeout in seconds when reading from database server.
|
||||||
|
# Default: 30
|
||||||
|
#ReceiveTimeout 60
|
||||||
|
|
||||||
|
# With this option enabled, freshclam will attempt to load new
|
||||||
|
# databases into memory to make sure they are properly handled
|
||||||
|
# by libclamav before replacing the old ones.
|
||||||
|
# Default: yes
|
||||||
|
#TestDatabases yes
|
||||||
|
|
||||||
|
# When enabled freshclam will submit statistics to the ClamAV Project about
|
||||||
|
# the latest virus detections in your environment. The ClamAV maintainers
|
||||||
|
# will then use this data to determine what types of malware are the most
|
||||||
|
# detected in the field and in what geographic area they are.
|
||||||
|
# Freshclam will connect to clamd in order to get recent statistics.
|
||||||
|
# Default: no
|
||||||
|
#SubmitDetectionStats /path/to/clamd.conf
|
||||||
|
|
||||||
|
# Country of origin of malware/detection statistics (for statistical
|
||||||
|
# purposes only). The statistics collector at ClamAV.net will look up
|
||||||
|
# your IP address to determine the geographical origin of the malware
|
||||||
|
# reported by your installation. If this installation is mainly used to
|
||||||
|
# scan data which comes from a different location, please enable this
|
||||||
|
# option and enter a two-letter code (see http://www.iana.org/domains/root/db/)
|
||||||
|
# of the country of origin.
|
||||||
|
# Default: disabled
|
||||||
|
#DetectionStatsCountry country-code
|
||||||
|
|
||||||
|
# This option enables support for our "Personal Statistics" service.
|
||||||
|
# When this option is enabled, the information on malware detected by
|
||||||
|
# your clamd installation is made available to you through our website.
|
||||||
|
# To get your HostID, log on http://www.stats.clamav.net and add a new
|
||||||
|
# host to your host list. Once you have the HostID, uncomment this option
|
||||||
|
# and paste the HostID here. As soon as your freshclam starts submitting
|
||||||
|
# information to our stats collecting service, you will be able to view
|
||||||
|
# the statistics of this clamd installation by logging into
|
||||||
|
# http://www.stats.clamav.net with the same credentials you used to
|
||||||
|
# generate the HostID. For more information refer to:
|
||||||
|
# http://www.clamav.net/documentation.html#cctts
|
||||||
|
# This feature requires SubmitDetectionStats to be enabled.
|
||||||
|
# Default: disabled
|
||||||
|
#DetectionStatsHostID unique-id
|
||||||
|
|
||||||
|
# This option enables support for Google Safe Browsing. When activated for
|
||||||
|
# the first time, freshclam will download a new database file (safebrowsing.cvd)
|
||||||
|
# which will be automatically loaded by clamd and clamscan during the next
|
||||||
|
# reload, provided that the heuristic phishing detection is turned on. This
|
||||||
|
# database includes information about websites that may be phishing sites or
|
||||||
|
# possible sources of malware. When using this option, it's mandatory to run
|
||||||
|
# freshclam at least every 30 minutes.
|
||||||
|
# Freshclam uses the ClamAV's mirror infrastructure to distribute the
|
||||||
|
# database and its updates but all the contents are provided under Google's
|
||||||
|
# terms of use. See http://www.google.com/transparencyreport/safebrowsing
|
||||||
|
# and http://www.clamav.net/documentation.html#safebrowsing
|
||||||
|
# for more information.
|
||||||
|
# Default: disabled
|
||||||
|
#SafeBrowsing yes
|
||||||
|
|
||||||
|
# This option enables downloading of bytecode.cvd, which includes additional
|
||||||
|
# detection mechanisms and improvements to the ClamAV engine.
|
||||||
|
# Default: enabled
|
||||||
|
#Bytecode yes
|
||||||
|
|
||||||
|
# Download an additional 3rd party signature database distributed through
|
||||||
|
# the ClamAV mirrors.
|
||||||
|
# This option can be used multiple times.
|
||||||
|
#ExtraDatabase dbname1
|
||||||
|
#ExtraDatabase dbname2
|
490
package-lock.json
generated
490
package-lock.json
generated
|
@ -22,6 +22,7 @@
|
||||||
"@inertiajs/inertia": "^0.11.1",
|
"@inertiajs/inertia": "^0.11.1",
|
||||||
"@inertiajs/vue3": "^1.0.0",
|
"@inertiajs/vue3": "^1.0.0",
|
||||||
"bcryptjs": "^2.4.3",
|
"bcryptjs": "^2.4.3",
|
||||||
|
"clamscan": "^2.1.2",
|
||||||
"crypto": "^1.0.1",
|
"crypto": "^1.0.1",
|
||||||
"dayjs": "^1.11.7",
|
"dayjs": "^1.11.7",
|
||||||
"http-status-codes": "^2.2.0",
|
"http-status-codes": "^2.2.0",
|
||||||
|
@ -49,6 +50,7 @@
|
||||||
"@mdi/js": "^7.1.96",
|
"@mdi/js": "^7.1.96",
|
||||||
"@symfony/webpack-encore": "^4.2.0",
|
"@symfony/webpack-encore": "^4.2.0",
|
||||||
"@tailwindcss/forms": "^0.5.2",
|
"@tailwindcss/forms": "^0.5.2",
|
||||||
|
"@types/clamscan": "^2.0.4",
|
||||||
"@types/leaflet": "^1.9.3",
|
"@types/leaflet": "^1.9.3",
|
||||||
"@types/node": "^20.1.1",
|
"@types/node": "^20.1.1",
|
||||||
"@types/proxy-addr": "^2.0.0",
|
"@types/proxy-addr": "^2.0.0",
|
||||||
|
@ -650,17 +652,17 @@
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/@adonisjs/validator": {
|
"node_modules/@adonisjs/validator": {
|
||||||
"version": "12.4.2",
|
"version": "12.5.0",
|
||||||
"resolved": "https://registry.npmjs.org/@adonisjs/validator/-/validator-12.4.2.tgz",
|
"resolved": "https://registry.npmjs.org/@adonisjs/validator/-/validator-12.5.0.tgz",
|
||||||
"integrity": "sha512-rEbZ2WUWywjffb8Aes6eKpoTb27+Nz3+Fy4wKg3/xSnAsGBKwVrKPOJADwcEFCcGjsNtEzk4llp8oviaQoaWTQ==",
|
"integrity": "sha512-88Lu+8OyS92A4mg0hE8AEjr8q9KmgZeR5obPGoAnCxBrptrsHHtKTQq242c+DbzuAWZzw5ZEX2dvv34PW/FmFw==",
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@poppinss/utils": "^5.0.0",
|
"@poppinss/utils": "^5.0.0",
|
||||||
"@types/luxon": "^3.0.1",
|
"@types/luxon": "^3.3.1",
|
||||||
"@types/validator": "^13.7.10",
|
"@types/validator": "^13.11.1",
|
||||||
"luxon": "^3.0.3",
|
"luxon": "^3.4.1",
|
||||||
"normalize-url": "^6.1.0",
|
"normalize-url": "^6.1.0",
|
||||||
"tmp-cache": "^1.1.0",
|
"tmp-cache": "^1.1.0",
|
||||||
"validator": "^13.7.0"
|
"validator": "^13.11.0"
|
||||||
},
|
},
|
||||||
"peerDependencies": {
|
"peerDependencies": {
|
||||||
"@adonisjs/application": "^5.0.0",
|
"@adonisjs/application": "^5.0.0",
|
||||||
|
@ -760,12 +762,12 @@
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/@babel/code-frame": {
|
"node_modules/@babel/code-frame": {
|
||||||
"version": "7.22.10",
|
"version": "7.22.13",
|
||||||
"resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.22.10.tgz",
|
"resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.22.13.tgz",
|
||||||
"integrity": "sha512-/KKIMG4UEL35WmI9OlvMhurwtytjvXoFcGNrOvyG9zIzA8YmPjVtIZUf7b05+TPO7G7/GEmLHDaoCgACHl9hhA==",
|
"integrity": "sha512-XktuhWlJ5g+3TJXc5upd9Ks1HutSArik6jf2eAjYFyIOf4ej3RN+184cZbzDvbPnuTJIUhPKKJE3cIsYTiAT3w==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@babel/highlight": "^7.22.10",
|
"@babel/highlight": "^7.22.13",
|
||||||
"chalk": "^2.4.2"
|
"chalk": "^2.4.2"
|
||||||
},
|
},
|
||||||
"engines": {
|
"engines": {
|
||||||
|
@ -782,9 +784,9 @@
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/@babel/core": {
|
"node_modules/@babel/core": {
|
||||||
"version": "7.22.10",
|
"version": "7.22.11",
|
||||||
"resolved": "https://registry.npmjs.org/@babel/core/-/core-7.22.10.tgz",
|
"resolved": "https://registry.npmjs.org/@babel/core/-/core-7.22.11.tgz",
|
||||||
"integrity": "sha512-fTmqbbUBAwCcre6zPzNngvsI0aNrPZe77AeqvDxWM9Nm+04RrJ3CAmGHA9f7lJQY6ZMhRztNemy4uslDxTX4Qw==",
|
"integrity": "sha512-lh7RJrtPdhibbxndr6/xx0w8+CVlY5FJZiaSz908Fpy+G0xkBFTvwLcKJFF4PJxVfGhVWNebikpWGnOoC71juQ==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@ampproject/remapping": "^2.2.0",
|
"@ampproject/remapping": "^2.2.0",
|
||||||
|
@ -792,15 +794,15 @@
|
||||||
"@babel/generator": "^7.22.10",
|
"@babel/generator": "^7.22.10",
|
||||||
"@babel/helper-compilation-targets": "^7.22.10",
|
"@babel/helper-compilation-targets": "^7.22.10",
|
||||||
"@babel/helper-module-transforms": "^7.22.9",
|
"@babel/helper-module-transforms": "^7.22.9",
|
||||||
"@babel/helpers": "^7.22.10",
|
"@babel/helpers": "^7.22.11",
|
||||||
"@babel/parser": "^7.22.10",
|
"@babel/parser": "^7.22.11",
|
||||||
"@babel/template": "^7.22.5",
|
"@babel/template": "^7.22.5",
|
||||||
"@babel/traverse": "^7.22.10",
|
"@babel/traverse": "^7.22.11",
|
||||||
"@babel/types": "^7.22.10",
|
"@babel/types": "^7.22.11",
|
||||||
"convert-source-map": "^1.7.0",
|
"convert-source-map": "^1.7.0",
|
||||||
"debug": "^4.1.0",
|
"debug": "^4.1.0",
|
||||||
"gensync": "^1.0.0-beta.2",
|
"gensync": "^1.0.0-beta.2",
|
||||||
"json5": "^2.2.2",
|
"json5": "^2.2.3",
|
||||||
"semver": "^6.3.1"
|
"semver": "^6.3.1"
|
||||||
},
|
},
|
||||||
"engines": {
|
"engines": {
|
||||||
|
@ -885,9 +887,9 @@
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/@babel/helper-create-class-features-plugin": {
|
"node_modules/@babel/helper-create-class-features-plugin": {
|
||||||
"version": "7.22.10",
|
"version": "7.22.11",
|
||||||
"resolved": "https://registry.npmjs.org/@babel/helper-create-class-features-plugin/-/helper-create-class-features-plugin-7.22.10.tgz",
|
"resolved": "https://registry.npmjs.org/@babel/helper-create-class-features-plugin/-/helper-create-class-features-plugin-7.22.11.tgz",
|
||||||
"integrity": "sha512-5IBb77txKYQPpOEdUdIhBx8VrZyDCQ+H82H0+5dX1TmuscP5vJKEE3cKurjtIw/vFwzbVH48VweE78kVDBrqjA==",
|
"integrity": "sha512-y1grdYL4WzmUDBRGK0pDbIoFd7UZKoDurDzWEoNMYoj1EL+foGRQNyPWDcC+YyegN5y1DUsFFmzjGijB3nSVAQ==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@babel/helper-annotate-as-pure": "^7.22.5",
|
"@babel/helper-annotate-as-pure": "^7.22.5",
|
||||||
|
@ -1168,23 +1170,23 @@
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/@babel/helpers": {
|
"node_modules/@babel/helpers": {
|
||||||
"version": "7.22.10",
|
"version": "7.22.11",
|
||||||
"resolved": "https://registry.npmjs.org/@babel/helpers/-/helpers-7.22.10.tgz",
|
"resolved": "https://registry.npmjs.org/@babel/helpers/-/helpers-7.22.11.tgz",
|
||||||
"integrity": "sha512-a41J4NW8HyZa1I1vAndrraTlPZ/eZoga2ZgS7fEr0tZJGVU4xqdE80CEm0CcNjha5EZ8fTBYLKHF0kqDUuAwQw==",
|
"integrity": "sha512-vyOXC8PBWaGc5h7GMsNx68OH33cypkEDJCHvYVVgVbbxJDROYVtexSk0gK5iCF1xNjRIN2s8ai7hwkWDq5szWg==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@babel/template": "^7.22.5",
|
"@babel/template": "^7.22.5",
|
||||||
"@babel/traverse": "^7.22.10",
|
"@babel/traverse": "^7.22.11",
|
||||||
"@babel/types": "^7.22.10"
|
"@babel/types": "^7.22.11"
|
||||||
},
|
},
|
||||||
"engines": {
|
"engines": {
|
||||||
"node": ">=6.9.0"
|
"node": ">=6.9.0"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/@babel/highlight": {
|
"node_modules/@babel/highlight": {
|
||||||
"version": "7.22.10",
|
"version": "7.22.13",
|
||||||
"resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.22.10.tgz",
|
"resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.22.13.tgz",
|
||||||
"integrity": "sha512-78aUtVcT7MUscr0K5mIEnkwxPE0MaxkR5RxRwuHaQ+JuU5AmTPhY+do2mdzVTnIJJpyBglql2pehuBIWHug+WQ==",
|
"integrity": "sha512-C/BaXcnnvBCmHTpz/VGZ8jgtE2aYlW4hxDhseJAWZb7gqGM/qtCK6iZUb0TyKFf7BOUsBH7Q7fkRsDRhg1XklQ==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@babel/helper-validator-identifier": "^7.22.5",
|
"@babel/helper-validator-identifier": "^7.22.5",
|
||||||
|
@ -1196,9 +1198,9 @@
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/@babel/parser": {
|
"node_modules/@babel/parser": {
|
||||||
"version": "7.22.10",
|
"version": "7.22.14",
|
||||||
"resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.22.10.tgz",
|
"resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.22.14.tgz",
|
||||||
"integrity": "sha512-lNbdGsQb9ekfsnjFGhEiF4hfFqGgfOP3H3d27re3n+CGhNuTSUEQdfWk556sTLNTloczcdM5TYF2LhzmDQKyvQ==",
|
"integrity": "sha512-1KucTHgOvaw/LzCVrEOAyXkr9rQlp0A1HiHRYnSUE9dmb8PvPW7o5sscg+5169r54n3vGlbx6GevTE/Iw/P3AQ==",
|
||||||
"bin": {
|
"bin": {
|
||||||
"parser": "bin/babel-parser.js"
|
"parser": "bin/babel-parser.js"
|
||||||
},
|
},
|
||||||
|
@ -1242,6 +1244,7 @@
|
||||||
"version": "7.18.6",
|
"version": "7.18.6",
|
||||||
"resolved": "https://registry.npmjs.org/@babel/plugin-proposal-class-properties/-/plugin-proposal-class-properties-7.18.6.tgz",
|
"resolved": "https://registry.npmjs.org/@babel/plugin-proposal-class-properties/-/plugin-proposal-class-properties-7.18.6.tgz",
|
||||||
"integrity": "sha512-cumfXOF0+nzZrrN8Rf0t7M+tF6sZc7vhQwYQck9q1/5w2OExlD+b4v4RpMJFaV1Z7WcDRgO6FqvxqxGlwo+RHQ==",
|
"integrity": "sha512-cumfXOF0+nzZrrN8Rf0t7M+tF6sZc7vhQwYQck9q1/5w2OExlD+b4v4RpMJFaV1Z7WcDRgO6FqvxqxGlwo+RHQ==",
|
||||||
|
"deprecated": "This proposal has been merged to the ECMAScript standard and thus this plugin is no longer maintained. Please use @babel/plugin-transform-class-properties instead.",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@babel/helper-create-class-features-plugin": "^7.18.6",
|
"@babel/helper-create-class-features-plugin": "^7.18.6",
|
||||||
|
@ -1581,9 +1584,9 @@
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/@babel/plugin-transform-async-generator-functions": {
|
"node_modules/@babel/plugin-transform-async-generator-functions": {
|
||||||
"version": "7.22.10",
|
"version": "7.22.11",
|
||||||
"resolved": "https://registry.npmjs.org/@babel/plugin-transform-async-generator-functions/-/plugin-transform-async-generator-functions-7.22.10.tgz",
|
"resolved": "https://registry.npmjs.org/@babel/plugin-transform-async-generator-functions/-/plugin-transform-async-generator-functions-7.22.11.tgz",
|
||||||
"integrity": "sha512-eueE8lvKVzq5wIObKK/7dvoeKJ+xc6TvRn6aysIjS6pSCeLy7S/eVi7pEQknZqyqvzaNKdDtem8nUNTBgDVR2g==",
|
"integrity": "sha512-0pAlmeRJn6wU84zzZsEOx1JV1Jf8fqO9ok7wofIJwUnplYo247dcd24P+cMJht7ts9xkzdtB0EPHmOb7F+KzXw==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@babel/helper-environment-visitor": "^7.22.5",
|
"@babel/helper-environment-visitor": "^7.22.5",
|
||||||
|
@ -1662,12 +1665,12 @@
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/@babel/plugin-transform-class-static-block": {
|
"node_modules/@babel/plugin-transform-class-static-block": {
|
||||||
"version": "7.22.5",
|
"version": "7.22.11",
|
||||||
"resolved": "https://registry.npmjs.org/@babel/plugin-transform-class-static-block/-/plugin-transform-class-static-block-7.22.5.tgz",
|
"resolved": "https://registry.npmjs.org/@babel/plugin-transform-class-static-block/-/plugin-transform-class-static-block-7.22.11.tgz",
|
||||||
"integrity": "sha512-SPToJ5eYZLxlnp1UzdARpOGeC2GbHvr9d/UV0EukuVx8atktg194oe+C5BqQ8jRTkgLRVOPYeXRSBg1IlMoVRA==",
|
"integrity": "sha512-GMM8gGmqI7guS/llMFk1bJDkKfn3v3C4KHK9Yg1ey5qcHcOlKb0QvcMrgzvxo+T03/4szNh5lghY+fEC98Kq9g==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@babel/helper-create-class-features-plugin": "^7.22.5",
|
"@babel/helper-create-class-features-plugin": "^7.22.11",
|
||||||
"@babel/helper-plugin-utils": "^7.22.5",
|
"@babel/helper-plugin-utils": "^7.22.5",
|
||||||
"@babel/plugin-syntax-class-static-block": "^7.14.5"
|
"@babel/plugin-syntax-class-static-block": "^7.14.5"
|
||||||
},
|
},
|
||||||
|
@ -1764,9 +1767,9 @@
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/@babel/plugin-transform-dynamic-import": {
|
"node_modules/@babel/plugin-transform-dynamic-import": {
|
||||||
"version": "7.22.5",
|
"version": "7.22.11",
|
||||||
"resolved": "https://registry.npmjs.org/@babel/plugin-transform-dynamic-import/-/plugin-transform-dynamic-import-7.22.5.tgz",
|
"resolved": "https://registry.npmjs.org/@babel/plugin-transform-dynamic-import/-/plugin-transform-dynamic-import-7.22.11.tgz",
|
||||||
"integrity": "sha512-0MC3ppTB1AMxd8fXjSrbPa7LT9hrImt+/fcj+Pg5YMD7UQyWp/02+JWpdnCymmsXwIx5Z+sYn1bwCn4ZJNvhqQ==",
|
"integrity": "sha512-g/21plo58sfteWjaO0ZNVb+uEOkJNjAaHhbejrnBmu011l/eNDScmkbjCC3l4FKb10ViaGU4aOkFznSu2zRHgA==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@babel/helper-plugin-utils": "^7.22.5",
|
"@babel/helper-plugin-utils": "^7.22.5",
|
||||||
|
@ -1796,9 +1799,9 @@
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/@babel/plugin-transform-export-namespace-from": {
|
"node_modules/@babel/plugin-transform-export-namespace-from": {
|
||||||
"version": "7.22.5",
|
"version": "7.22.11",
|
||||||
"resolved": "https://registry.npmjs.org/@babel/plugin-transform-export-namespace-from/-/plugin-transform-export-namespace-from-7.22.5.tgz",
|
"resolved": "https://registry.npmjs.org/@babel/plugin-transform-export-namespace-from/-/plugin-transform-export-namespace-from-7.22.11.tgz",
|
||||||
"integrity": "sha512-X4hhm7FRnPgd4nDA4b/5V280xCx6oL7Oob5+9qVS5C13Zq4bh1qq7LU0GgRU6b5dBWBvhGaXYVB4AcN6+ol6vg==",
|
"integrity": "sha512-xa7aad7q7OiT8oNZ1mU7NrISjlSkVdMbNxn9IuLZyL9AJEhs1Apba3I+u5riX1dIkdptP5EKDG5XDPByWxtehw==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@babel/helper-plugin-utils": "^7.22.5",
|
"@babel/helper-plugin-utils": "^7.22.5",
|
||||||
|
@ -1844,9 +1847,9 @@
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/@babel/plugin-transform-json-strings": {
|
"node_modules/@babel/plugin-transform-json-strings": {
|
||||||
"version": "7.22.5",
|
"version": "7.22.11",
|
||||||
"resolved": "https://registry.npmjs.org/@babel/plugin-transform-json-strings/-/plugin-transform-json-strings-7.22.5.tgz",
|
"resolved": "https://registry.npmjs.org/@babel/plugin-transform-json-strings/-/plugin-transform-json-strings-7.22.11.tgz",
|
||||||
"integrity": "sha512-DuCRB7fu8MyTLbEQd1ew3R85nx/88yMoqo2uPSjevMj3yoN7CDM8jkgrY0wmVxfJZyJ/B9fE1iq7EQppWQmR5A==",
|
"integrity": "sha512-CxT5tCqpA9/jXFlme9xIBCc5RPtdDq3JpkkhgHQqtDdiTnTI0jtZ0QzXhr5DILeYifDPp2wvY2ad+7+hLMW5Pw==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@babel/helper-plugin-utils": "^7.22.5",
|
"@babel/helper-plugin-utils": "^7.22.5",
|
||||||
|
@ -1875,9 +1878,9 @@
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/@babel/plugin-transform-logical-assignment-operators": {
|
"node_modules/@babel/plugin-transform-logical-assignment-operators": {
|
||||||
"version": "7.22.5",
|
"version": "7.22.11",
|
||||||
"resolved": "https://registry.npmjs.org/@babel/plugin-transform-logical-assignment-operators/-/plugin-transform-logical-assignment-operators-7.22.5.tgz",
|
"resolved": "https://registry.npmjs.org/@babel/plugin-transform-logical-assignment-operators/-/plugin-transform-logical-assignment-operators-7.22.11.tgz",
|
||||||
"integrity": "sha512-MQQOUW1KL8X0cDWfbwYP+TbVbZm16QmQXJQ+vndPtH/BoO0lOKpVoEDMI7+PskYxH+IiE0tS8xZye0qr1lGzSA==",
|
"integrity": "sha512-qQwRTP4+6xFCDV5k7gZBF3C31K34ut0tbEcTKxlX/0KXxm9GLcO14p570aWxFvVzx6QAfPgq7gaeIHXJC8LswQ==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@babel/helper-plugin-utils": "^7.22.5",
|
"@babel/helper-plugin-utils": "^7.22.5",
|
||||||
|
@ -1922,12 +1925,12 @@
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/@babel/plugin-transform-modules-commonjs": {
|
"node_modules/@babel/plugin-transform-modules-commonjs": {
|
||||||
"version": "7.22.5",
|
"version": "7.22.11",
|
||||||
"resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-commonjs/-/plugin-transform-modules-commonjs-7.22.5.tgz",
|
"resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-commonjs/-/plugin-transform-modules-commonjs-7.22.11.tgz",
|
||||||
"integrity": "sha512-B4pzOXj+ONRmuaQTg05b3y/4DuFz3WcCNAXPLb2Q0GT0TrGKGxNKV4jwsXts+StaM0LQczZbOpj8o1DLPDJIiA==",
|
"integrity": "sha512-o2+bg7GDS60cJMgz9jWqRUsWkMzLCxp+jFDeDUT5sjRlAxcJWZ2ylNdI7QQ2+CH5hWu7OnN+Cv3htt7AkSf96g==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@babel/helper-module-transforms": "^7.22.5",
|
"@babel/helper-module-transforms": "^7.22.9",
|
||||||
"@babel/helper-plugin-utils": "^7.22.5",
|
"@babel/helper-plugin-utils": "^7.22.5",
|
||||||
"@babel/helper-simple-access": "^7.22.5"
|
"@babel/helper-simple-access": "^7.22.5"
|
||||||
},
|
},
|
||||||
|
@ -1939,13 +1942,13 @@
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/@babel/plugin-transform-modules-systemjs": {
|
"node_modules/@babel/plugin-transform-modules-systemjs": {
|
||||||
"version": "7.22.5",
|
"version": "7.22.11",
|
||||||
"resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-systemjs/-/plugin-transform-modules-systemjs-7.22.5.tgz",
|
"resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-systemjs/-/plugin-transform-modules-systemjs-7.22.11.tgz",
|
||||||
"integrity": "sha512-emtEpoaTMsOs6Tzz+nbmcePl6AKVtS1yC4YNAeMun9U8YCsgadPNxnOPQ8GhHFB2qdx+LZu9LgoC0Lthuu05DQ==",
|
"integrity": "sha512-rIqHmHoMEOhI3VkVf5jQ15l539KrwhzqcBO6wdCNWPWc/JWt9ILNYNUssbRpeq0qWns8svuw8LnMNCvWBIJ8wA==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@babel/helper-hoist-variables": "^7.22.5",
|
"@babel/helper-hoist-variables": "^7.22.5",
|
||||||
"@babel/helper-module-transforms": "^7.22.5",
|
"@babel/helper-module-transforms": "^7.22.9",
|
||||||
"@babel/helper-plugin-utils": "^7.22.5",
|
"@babel/helper-plugin-utils": "^7.22.5",
|
||||||
"@babel/helper-validator-identifier": "^7.22.5"
|
"@babel/helper-validator-identifier": "^7.22.5"
|
||||||
},
|
},
|
||||||
|
@ -2004,9 +2007,9 @@
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/@babel/plugin-transform-nullish-coalescing-operator": {
|
"node_modules/@babel/plugin-transform-nullish-coalescing-operator": {
|
||||||
"version": "7.22.5",
|
"version": "7.22.11",
|
||||||
"resolved": "https://registry.npmjs.org/@babel/plugin-transform-nullish-coalescing-operator/-/plugin-transform-nullish-coalescing-operator-7.22.5.tgz",
|
"resolved": "https://registry.npmjs.org/@babel/plugin-transform-nullish-coalescing-operator/-/plugin-transform-nullish-coalescing-operator-7.22.11.tgz",
|
||||||
"integrity": "sha512-6CF8g6z1dNYZ/VXok5uYkkBBICHZPiGEl7oDnAx2Mt1hlHVHOSIKWJaXHjQJA5VB43KZnXZDIexMchY4y2PGdA==",
|
"integrity": "sha512-YZWOw4HxXrotb5xsjMJUDlLgcDXSfO9eCmdl1bgW4+/lAGdkjaEvOnQ4p5WKKdUgSzO39dgPl0pTnfxm0OAXcg==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@babel/helper-plugin-utils": "^7.22.5",
|
"@babel/helper-plugin-utils": "^7.22.5",
|
||||||
|
@ -2020,9 +2023,9 @@
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/@babel/plugin-transform-numeric-separator": {
|
"node_modules/@babel/plugin-transform-numeric-separator": {
|
||||||
"version": "7.22.5",
|
"version": "7.22.11",
|
||||||
"resolved": "https://registry.npmjs.org/@babel/plugin-transform-numeric-separator/-/plugin-transform-numeric-separator-7.22.5.tgz",
|
"resolved": "https://registry.npmjs.org/@babel/plugin-transform-numeric-separator/-/plugin-transform-numeric-separator-7.22.11.tgz",
|
||||||
"integrity": "sha512-NbslED1/6M+sXiwwtcAB/nieypGw02Ejf4KtDeMkCEpP6gWFMX1wI9WKYua+4oBneCCEmulOkRpwywypVZzs/g==",
|
"integrity": "sha512-3dzU4QGPsILdJbASKhF/V2TVP+gJya1PsueQCxIPCEcerqF21oEcrob4mzjsp2Py/1nLfF5m+xYNMDpmA8vffg==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@babel/helper-plugin-utils": "^7.22.5",
|
"@babel/helper-plugin-utils": "^7.22.5",
|
||||||
|
@ -2036,13 +2039,13 @@
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/@babel/plugin-transform-object-rest-spread": {
|
"node_modules/@babel/plugin-transform-object-rest-spread": {
|
||||||
"version": "7.22.5",
|
"version": "7.22.11",
|
||||||
"resolved": "https://registry.npmjs.org/@babel/plugin-transform-object-rest-spread/-/plugin-transform-object-rest-spread-7.22.5.tgz",
|
"resolved": "https://registry.npmjs.org/@babel/plugin-transform-object-rest-spread/-/plugin-transform-object-rest-spread-7.22.11.tgz",
|
||||||
"integrity": "sha512-Kk3lyDmEslH9DnvCDA1s1kkd3YWQITiBOHngOtDL9Pt6BZjzqb6hiOlb8VfjiiQJ2unmegBqZu0rx5RxJb5vmQ==",
|
"integrity": "sha512-nX8cPFa6+UmbepISvlf5jhQyaC7ASs/7UxHmMkuJ/k5xSHvDPPaibMo+v3TXwU/Pjqhep/nFNpd3zn4YR59pnw==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@babel/compat-data": "^7.22.5",
|
"@babel/compat-data": "^7.22.9",
|
||||||
"@babel/helper-compilation-targets": "^7.22.5",
|
"@babel/helper-compilation-targets": "^7.22.10",
|
||||||
"@babel/helper-plugin-utils": "^7.22.5",
|
"@babel/helper-plugin-utils": "^7.22.5",
|
||||||
"@babel/plugin-syntax-object-rest-spread": "^7.8.3",
|
"@babel/plugin-syntax-object-rest-spread": "^7.8.3",
|
||||||
"@babel/plugin-transform-parameters": "^7.22.5"
|
"@babel/plugin-transform-parameters": "^7.22.5"
|
||||||
|
@ -2071,9 +2074,9 @@
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/@babel/plugin-transform-optional-catch-binding": {
|
"node_modules/@babel/plugin-transform-optional-catch-binding": {
|
||||||
"version": "7.22.5",
|
"version": "7.22.11",
|
||||||
"resolved": "https://registry.npmjs.org/@babel/plugin-transform-optional-catch-binding/-/plugin-transform-optional-catch-binding-7.22.5.tgz",
|
"resolved": "https://registry.npmjs.org/@babel/plugin-transform-optional-catch-binding/-/plugin-transform-optional-catch-binding-7.22.11.tgz",
|
||||||
"integrity": "sha512-pH8orJahy+hzZje5b8e2QIlBWQvGpelS76C63Z+jhZKsmzfNaPQ+LaW6dcJ9bxTpo1mtXbgHwy765Ro3jftmUg==",
|
"integrity": "sha512-rli0WxesXUeCJnMYhzAglEjLWVDF6ahb45HuprcmQuLidBJFWjNnOzssk2kuc6e33FlLaiZhG/kUIzUMWdBKaQ==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@babel/helper-plugin-utils": "^7.22.5",
|
"@babel/helper-plugin-utils": "^7.22.5",
|
||||||
|
@ -2087,9 +2090,9 @@
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/@babel/plugin-transform-optional-chaining": {
|
"node_modules/@babel/plugin-transform-optional-chaining": {
|
||||||
"version": "7.22.10",
|
"version": "7.22.12",
|
||||||
"resolved": "https://registry.npmjs.org/@babel/plugin-transform-optional-chaining/-/plugin-transform-optional-chaining-7.22.10.tgz",
|
"resolved": "https://registry.npmjs.org/@babel/plugin-transform-optional-chaining/-/plugin-transform-optional-chaining-7.22.12.tgz",
|
||||||
"integrity": "sha512-MMkQqZAZ+MGj+jGTG3OTuhKeBpNcO+0oCEbrGNEaOmiEn+1MzRyQlYsruGiU8RTK3zV6XwrVJTmwiDOyYK6J9g==",
|
"integrity": "sha512-7XXCVqZtyFWqjDsYDY4T45w4mlx1rf7aOgkc/Ww76xkgBiOlmjPkx36PBLHa1k1rwWvVgYMPsbuVnIamx2ZQJw==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@babel/helper-plugin-utils": "^7.22.5",
|
"@babel/helper-plugin-utils": "^7.22.5",
|
||||||
|
@ -2135,13 +2138,13 @@
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/@babel/plugin-transform-private-property-in-object": {
|
"node_modules/@babel/plugin-transform-private-property-in-object": {
|
||||||
"version": "7.22.5",
|
"version": "7.22.11",
|
||||||
"resolved": "https://registry.npmjs.org/@babel/plugin-transform-private-property-in-object/-/plugin-transform-private-property-in-object-7.22.5.tgz",
|
"resolved": "https://registry.npmjs.org/@babel/plugin-transform-private-property-in-object/-/plugin-transform-private-property-in-object-7.22.11.tgz",
|
||||||
"integrity": "sha512-/9xnaTTJcVoBtSSmrVyhtSvO3kbqS2ODoh2juEU72c3aYonNF0OMGiaz2gjukyKM2wBBYJP38S4JiE0Wfb5VMQ==",
|
"integrity": "sha512-sSCbqZDBKHetvjSwpyWzhuHkmW5RummxJBVbYLkGkaiTOWGxml7SXt0iWa03bzxFIx7wOj3g/ILRd0RcJKBeSQ==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@babel/helper-annotate-as-pure": "^7.22.5",
|
"@babel/helper-annotate-as-pure": "^7.22.5",
|
||||||
"@babel/helper-create-class-features-plugin": "^7.22.5",
|
"@babel/helper-create-class-features-plugin": "^7.22.11",
|
||||||
"@babel/helper-plugin-utils": "^7.22.5",
|
"@babel/helper-plugin-utils": "^7.22.5",
|
||||||
"@babel/plugin-syntax-private-property-in-object": "^7.14.5"
|
"@babel/plugin-syntax-private-property-in-object": "^7.14.5"
|
||||||
},
|
},
|
||||||
|
@ -2304,13 +2307,13 @@
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/@babel/plugin-transform-typescript": {
|
"node_modules/@babel/plugin-transform-typescript": {
|
||||||
"version": "7.22.10",
|
"version": "7.22.11",
|
||||||
"resolved": "https://registry.npmjs.org/@babel/plugin-transform-typescript/-/plugin-transform-typescript-7.22.10.tgz",
|
"resolved": "https://registry.npmjs.org/@babel/plugin-transform-typescript/-/plugin-transform-typescript-7.22.11.tgz",
|
||||||
"integrity": "sha512-7++c8I/ymsDo4QQBAgbraXLzIM6jmfao11KgIBEYZRReWzNWH9NtNgJcyrZiXsOPh523FQm6LfpLyy/U5fn46A==",
|
"integrity": "sha512-0E4/L+7gfvHub7wsbTv03oRtD69X31LByy44fGmFzbZScpupFByMcgCJ0VbBTkzyjSJKuRoGN8tcijOWKTmqOA==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@babel/helper-annotate-as-pure": "^7.22.5",
|
"@babel/helper-annotate-as-pure": "^7.22.5",
|
||||||
"@babel/helper-create-class-features-plugin": "^7.22.10",
|
"@babel/helper-create-class-features-plugin": "^7.22.11",
|
||||||
"@babel/helper-plugin-utils": "^7.22.5",
|
"@babel/helper-plugin-utils": "^7.22.5",
|
||||||
"@babel/plugin-syntax-typescript": "^7.22.5"
|
"@babel/plugin-syntax-typescript": "^7.22.5"
|
||||||
},
|
},
|
||||||
|
@ -2385,9 +2388,9 @@
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/@babel/preset-env": {
|
"node_modules/@babel/preset-env": {
|
||||||
"version": "7.22.10",
|
"version": "7.22.14",
|
||||||
"resolved": "https://registry.npmjs.org/@babel/preset-env/-/preset-env-7.22.10.tgz",
|
"resolved": "https://registry.npmjs.org/@babel/preset-env/-/preset-env-7.22.14.tgz",
|
||||||
"integrity": "sha512-riHpLb1drNkpLlocmSyEg4oYJIQFeXAK/d7rI6mbD0XsvoTOOweXDmQPG/ErxsEhWk3rl3Q/3F6RFQlVFS8m0A==",
|
"integrity": "sha512-daodMIoVo+ol/g+//c/AH+szBkFj4STQUikvBijRGL72Ph+w+AMTSh55DUETe8KJlPlDT1k/mp7NBfOuiWmoig==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@babel/compat-data": "^7.22.9",
|
"@babel/compat-data": "^7.22.9",
|
||||||
|
@ -2416,41 +2419,41 @@
|
||||||
"@babel/plugin-syntax-top-level-await": "^7.14.5",
|
"@babel/plugin-syntax-top-level-await": "^7.14.5",
|
||||||
"@babel/plugin-syntax-unicode-sets-regex": "^7.18.6",
|
"@babel/plugin-syntax-unicode-sets-regex": "^7.18.6",
|
||||||
"@babel/plugin-transform-arrow-functions": "^7.22.5",
|
"@babel/plugin-transform-arrow-functions": "^7.22.5",
|
||||||
"@babel/plugin-transform-async-generator-functions": "^7.22.10",
|
"@babel/plugin-transform-async-generator-functions": "^7.22.11",
|
||||||
"@babel/plugin-transform-async-to-generator": "^7.22.5",
|
"@babel/plugin-transform-async-to-generator": "^7.22.5",
|
||||||
"@babel/plugin-transform-block-scoped-functions": "^7.22.5",
|
"@babel/plugin-transform-block-scoped-functions": "^7.22.5",
|
||||||
"@babel/plugin-transform-block-scoping": "^7.22.10",
|
"@babel/plugin-transform-block-scoping": "^7.22.10",
|
||||||
"@babel/plugin-transform-class-properties": "^7.22.5",
|
"@babel/plugin-transform-class-properties": "^7.22.5",
|
||||||
"@babel/plugin-transform-class-static-block": "^7.22.5",
|
"@babel/plugin-transform-class-static-block": "^7.22.11",
|
||||||
"@babel/plugin-transform-classes": "^7.22.6",
|
"@babel/plugin-transform-classes": "^7.22.6",
|
||||||
"@babel/plugin-transform-computed-properties": "^7.22.5",
|
"@babel/plugin-transform-computed-properties": "^7.22.5",
|
||||||
"@babel/plugin-transform-destructuring": "^7.22.10",
|
"@babel/plugin-transform-destructuring": "^7.22.10",
|
||||||
"@babel/plugin-transform-dotall-regex": "^7.22.5",
|
"@babel/plugin-transform-dotall-regex": "^7.22.5",
|
||||||
"@babel/plugin-transform-duplicate-keys": "^7.22.5",
|
"@babel/plugin-transform-duplicate-keys": "^7.22.5",
|
||||||
"@babel/plugin-transform-dynamic-import": "^7.22.5",
|
"@babel/plugin-transform-dynamic-import": "^7.22.11",
|
||||||
"@babel/plugin-transform-exponentiation-operator": "^7.22.5",
|
"@babel/plugin-transform-exponentiation-operator": "^7.22.5",
|
||||||
"@babel/plugin-transform-export-namespace-from": "^7.22.5",
|
"@babel/plugin-transform-export-namespace-from": "^7.22.11",
|
||||||
"@babel/plugin-transform-for-of": "^7.22.5",
|
"@babel/plugin-transform-for-of": "^7.22.5",
|
||||||
"@babel/plugin-transform-function-name": "^7.22.5",
|
"@babel/plugin-transform-function-name": "^7.22.5",
|
||||||
"@babel/plugin-transform-json-strings": "^7.22.5",
|
"@babel/plugin-transform-json-strings": "^7.22.11",
|
||||||
"@babel/plugin-transform-literals": "^7.22.5",
|
"@babel/plugin-transform-literals": "^7.22.5",
|
||||||
"@babel/plugin-transform-logical-assignment-operators": "^7.22.5",
|
"@babel/plugin-transform-logical-assignment-operators": "^7.22.11",
|
||||||
"@babel/plugin-transform-member-expression-literals": "^7.22.5",
|
"@babel/plugin-transform-member-expression-literals": "^7.22.5",
|
||||||
"@babel/plugin-transform-modules-amd": "^7.22.5",
|
"@babel/plugin-transform-modules-amd": "^7.22.5",
|
||||||
"@babel/plugin-transform-modules-commonjs": "^7.22.5",
|
"@babel/plugin-transform-modules-commonjs": "^7.22.11",
|
||||||
"@babel/plugin-transform-modules-systemjs": "^7.22.5",
|
"@babel/plugin-transform-modules-systemjs": "^7.22.11",
|
||||||
"@babel/plugin-transform-modules-umd": "^7.22.5",
|
"@babel/plugin-transform-modules-umd": "^7.22.5",
|
||||||
"@babel/plugin-transform-named-capturing-groups-regex": "^7.22.5",
|
"@babel/plugin-transform-named-capturing-groups-regex": "^7.22.5",
|
||||||
"@babel/plugin-transform-new-target": "^7.22.5",
|
"@babel/plugin-transform-new-target": "^7.22.5",
|
||||||
"@babel/plugin-transform-nullish-coalescing-operator": "^7.22.5",
|
"@babel/plugin-transform-nullish-coalescing-operator": "^7.22.11",
|
||||||
"@babel/plugin-transform-numeric-separator": "^7.22.5",
|
"@babel/plugin-transform-numeric-separator": "^7.22.11",
|
||||||
"@babel/plugin-transform-object-rest-spread": "^7.22.5",
|
"@babel/plugin-transform-object-rest-spread": "^7.22.11",
|
||||||
"@babel/plugin-transform-object-super": "^7.22.5",
|
"@babel/plugin-transform-object-super": "^7.22.5",
|
||||||
"@babel/plugin-transform-optional-catch-binding": "^7.22.5",
|
"@babel/plugin-transform-optional-catch-binding": "^7.22.11",
|
||||||
"@babel/plugin-transform-optional-chaining": "^7.22.10",
|
"@babel/plugin-transform-optional-chaining": "^7.22.12",
|
||||||
"@babel/plugin-transform-parameters": "^7.22.5",
|
"@babel/plugin-transform-parameters": "^7.22.5",
|
||||||
"@babel/plugin-transform-private-methods": "^7.22.5",
|
"@babel/plugin-transform-private-methods": "^7.22.5",
|
||||||
"@babel/plugin-transform-private-property-in-object": "^7.22.5",
|
"@babel/plugin-transform-private-property-in-object": "^7.22.11",
|
||||||
"@babel/plugin-transform-property-literals": "^7.22.5",
|
"@babel/plugin-transform-property-literals": "^7.22.5",
|
||||||
"@babel/plugin-transform-regenerator": "^7.22.10",
|
"@babel/plugin-transform-regenerator": "^7.22.10",
|
||||||
"@babel/plugin-transform-reserved-words": "^7.22.5",
|
"@babel/plugin-transform-reserved-words": "^7.22.5",
|
||||||
|
@ -2464,7 +2467,7 @@
|
||||||
"@babel/plugin-transform-unicode-regex": "^7.22.5",
|
"@babel/plugin-transform-unicode-regex": "^7.22.5",
|
||||||
"@babel/plugin-transform-unicode-sets-regex": "^7.22.5",
|
"@babel/plugin-transform-unicode-sets-regex": "^7.22.5",
|
||||||
"@babel/preset-modules": "0.1.6-no-external-plugins",
|
"@babel/preset-modules": "0.1.6-no-external-plugins",
|
||||||
"@babel/types": "^7.22.10",
|
"@babel/types": "^7.22.11",
|
||||||
"babel-plugin-polyfill-corejs2": "^0.4.5",
|
"babel-plugin-polyfill-corejs2": "^0.4.5",
|
||||||
"babel-plugin-polyfill-corejs3": "^0.8.3",
|
"babel-plugin-polyfill-corejs3": "^0.8.3",
|
||||||
"babel-plugin-polyfill-regenerator": "^0.5.2",
|
"babel-plugin-polyfill-regenerator": "^0.5.2",
|
||||||
|
@ -2502,16 +2505,16 @@
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/@babel/preset-typescript": {
|
"node_modules/@babel/preset-typescript": {
|
||||||
"version": "7.22.5",
|
"version": "7.22.11",
|
||||||
"resolved": "https://registry.npmjs.org/@babel/preset-typescript/-/preset-typescript-7.22.5.tgz",
|
"resolved": "https://registry.npmjs.org/@babel/preset-typescript/-/preset-typescript-7.22.11.tgz",
|
||||||
"integrity": "sha512-YbPaal9LxztSGhmndR46FmAbkJ/1fAsw293tSU+I5E5h+cnJ3d4GTwyUgGYmOXJYdGA+uNePle4qbaRzj2NISQ==",
|
"integrity": "sha512-tWY5wyCZYBGY7IlalfKI1rLiGlIfnwsRHZqlky0HVv8qviwQ1Uo/05M6+s+TcTCVa6Bmoo2uJW5TMFX6Wa4qVg==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@babel/helper-plugin-utils": "^7.22.5",
|
"@babel/helper-plugin-utils": "^7.22.5",
|
||||||
"@babel/helper-validator-option": "^7.22.5",
|
"@babel/helper-validator-option": "^7.22.5",
|
||||||
"@babel/plugin-syntax-jsx": "^7.22.5",
|
"@babel/plugin-syntax-jsx": "^7.22.5",
|
||||||
"@babel/plugin-transform-modules-commonjs": "^7.22.5",
|
"@babel/plugin-transform-modules-commonjs": "^7.22.11",
|
||||||
"@babel/plugin-transform-typescript": "^7.22.5"
|
"@babel/plugin-transform-typescript": "^7.22.11"
|
||||||
},
|
},
|
||||||
"engines": {
|
"engines": {
|
||||||
"node": ">=6.9.0"
|
"node": ">=6.9.0"
|
||||||
|
@ -2527,9 +2530,9 @@
|
||||||
"dev": true
|
"dev": true
|
||||||
},
|
},
|
||||||
"node_modules/@babel/runtime": {
|
"node_modules/@babel/runtime": {
|
||||||
"version": "7.22.10",
|
"version": "7.22.11",
|
||||||
"resolved": "https://registry.npmjs.org/@babel/runtime/-/runtime-7.22.10.tgz",
|
"resolved": "https://registry.npmjs.org/@babel/runtime/-/runtime-7.22.11.tgz",
|
||||||
"integrity": "sha512-21t/fkKLMZI4pqP2wlmsQAWnYW1PDyKyyUV4vCi+B25ydmdaYTKXPwCj0BzSUnZf4seIiYvSA3jcZ3gdsMFkLQ==",
|
"integrity": "sha512-ee7jVNlWN09+KftVOu9n7S8gQzD/Z6hN/I8VBRXW4P1+Xe7kJGXMwu8vds4aGIMHZnNbdpSWCfZZtinytpcAvA==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"regenerator-runtime": "^0.14.0"
|
"regenerator-runtime": "^0.14.0"
|
||||||
|
@ -2553,9 +2556,9 @@
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/@babel/traverse": {
|
"node_modules/@babel/traverse": {
|
||||||
"version": "7.22.10",
|
"version": "7.22.11",
|
||||||
"resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.22.10.tgz",
|
"resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.22.11.tgz",
|
||||||
"integrity": "sha512-Q/urqV4pRByiNNpb/f5OSv28ZlGJiFiiTh+GAHktbIrkPhPbl90+uW6SmpoLyZqutrg9AEaEf3Q/ZBRHBXgxig==",
|
"integrity": "sha512-mzAenteTfomcB7mfPtyi+4oe5BZ6MXxWcn4CX+h4IRJ+OOGXBrWU6jDQavkQI9Vuc5P+donFabBfFCcmWka9lQ==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@babel/code-frame": "^7.22.10",
|
"@babel/code-frame": "^7.22.10",
|
||||||
|
@ -2564,8 +2567,8 @@
|
||||||
"@babel/helper-function-name": "^7.22.5",
|
"@babel/helper-function-name": "^7.22.5",
|
||||||
"@babel/helper-hoist-variables": "^7.22.5",
|
"@babel/helper-hoist-variables": "^7.22.5",
|
||||||
"@babel/helper-split-export-declaration": "^7.22.6",
|
"@babel/helper-split-export-declaration": "^7.22.6",
|
||||||
"@babel/parser": "^7.22.10",
|
"@babel/parser": "^7.22.11",
|
||||||
"@babel/types": "^7.22.10",
|
"@babel/types": "^7.22.11",
|
||||||
"debug": "^4.1.0",
|
"debug": "^4.1.0",
|
||||||
"globals": "^11.1.0"
|
"globals": "^11.1.0"
|
||||||
},
|
},
|
||||||
|
@ -2574,9 +2577,9 @@
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/@babel/types": {
|
"node_modules/@babel/types": {
|
||||||
"version": "7.22.10",
|
"version": "7.22.11",
|
||||||
"resolved": "https://registry.npmjs.org/@babel/types/-/types-7.22.10.tgz",
|
"resolved": "https://registry.npmjs.org/@babel/types/-/types-7.22.11.tgz",
|
||||||
"integrity": "sha512-obaoigiLrlDZ7TUQln/8m4mSqIW2QFeOrCQc9r+xsaHGNoplVNYlRVpsfE8Vj35GEm2ZH4ZhrNYogs/3fj85kg==",
|
"integrity": "sha512-siazHiGuZRz9aB9NpHy9GOs9xiQPKnMzgdr493iI1M67vRXpnEq8ZOOKzezC5q7zwuQ6sDhdSp4SD9ixKSqKZg==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@babel/helper-string-parser": "^7.22.5",
|
"@babel/helper-string-parser": "^7.22.5",
|
||||||
|
@ -2671,9 +2674,9 @@
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/@eslint-community/regexpp": {
|
"node_modules/@eslint-community/regexpp": {
|
||||||
"version": "4.7.0",
|
"version": "4.8.0",
|
||||||
"resolved": "https://registry.npmjs.org/@eslint-community/regexpp/-/regexpp-4.7.0.tgz",
|
"resolved": "https://registry.npmjs.org/@eslint-community/regexpp/-/regexpp-4.8.0.tgz",
|
||||||
"integrity": "sha512-+HencqxU7CFJnQb7IKtuNBqS6Yx3Tz4kOL8BJXo+JyeiBm5MEX6pO8onXDkjrkCRlfYXS1Axro15ZjVFe9YgsA==",
|
"integrity": "sha512-JylOEEzDiOryeUnFbQz+oViCXS0KsvR1mvHkoMiu5+UiBvy+RYX7tzlIIIEstF/gVa2tj9AQXk3dgnxv6KxhFg==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"engines": {
|
"engines": {
|
||||||
"node": "^12.0.0 || ^14.0.0 || >=16.0.0"
|
"node": "^12.0.0 || ^14.0.0 || >=16.0.0"
|
||||||
|
@ -2748,9 +2751,9 @@
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/@eslint/js": {
|
"node_modules/@eslint/js": {
|
||||||
"version": "8.47.0",
|
"version": "8.48.0",
|
||||||
"resolved": "https://registry.npmjs.org/@eslint/js/-/js-8.47.0.tgz",
|
"resolved": "https://registry.npmjs.org/@eslint/js/-/js-8.48.0.tgz",
|
||||||
"integrity": "sha512-P6omY1zv5MItm93kLM8s2vr1HICJH8v0dvddDhysbIuZ+vcjOHg5Zbkf1mTkcmi2JA9oBG2anOkRnW8WJTS8Og==",
|
"integrity": "sha512-ZSjtmelB7IJfWD2Fvb7+Z+ChTIKWq6kjda95fLcQKNS5aheVHn4IkfgRQE3sIIzTcSLwLcLZUD9UBt+V7+h+Pw==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"engines": {
|
"engines": {
|
||||||
"node": "^12.22.0 || ^14.17.0 || >=16.0.0"
|
"node": "^12.22.0 || ^14.17.0 || >=16.0.0"
|
||||||
|
@ -2772,9 +2775,9 @@
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/@fontsource/archivo-black": {
|
"node_modules/@fontsource/archivo-black": {
|
||||||
"version": "5.0.8",
|
"version": "5.0.11",
|
||||||
"resolved": "https://registry.npmjs.org/@fontsource/archivo-black/-/archivo-black-5.0.8.tgz",
|
"resolved": "https://registry.npmjs.org/@fontsource/archivo-black/-/archivo-black-5.0.11.tgz",
|
||||||
"integrity": "sha512-mpsgUK6Tuetq+074N1bZJj0oikUiOV3QvMLBUrJxG6tEJMrIK2OPPhWzL/6lK+rUnOFXgL8mQSH+1yOcJwYBmA=="
|
"integrity": "sha512-J5Cs9kUZRJgP/uBbUHak/2mw0Oky2REk7TYTnjzySSkSqvxsjDQlH8oLJM/mpU5OJ39pukzae16U6/qzWBPiMw=="
|
||||||
},
|
},
|
||||||
"node_modules/@fontsource/inter": {
|
"node_modules/@fontsource/inter": {
|
||||||
"version": "5.0.8",
|
"version": "5.0.8",
|
||||||
|
@ -2782,9 +2785,9 @@
|
||||||
"integrity": "sha512-28knWH1BfOiRalfLs90U4sge5mpQ8ZH6FS0PTT+IZMKrZ7wNHDHRuKa1kQJg+uHcc6axBppnxll+HXM4c7zo/Q=="
|
"integrity": "sha512-28knWH1BfOiRalfLs90U4sge5mpQ8ZH6FS0PTT+IZMKrZ7wNHDHRuKa1kQJg+uHcc6axBppnxll+HXM4c7zo/Q=="
|
||||||
},
|
},
|
||||||
"node_modules/@humanwhocodes/config-array": {
|
"node_modules/@humanwhocodes/config-array": {
|
||||||
"version": "0.11.10",
|
"version": "0.11.11",
|
||||||
"resolved": "https://registry.npmjs.org/@humanwhocodes/config-array/-/config-array-0.11.10.tgz",
|
"resolved": "https://registry.npmjs.org/@humanwhocodes/config-array/-/config-array-0.11.11.tgz",
|
||||||
"integrity": "sha512-KVVjQmNUepDVGXNuoRRdmmEjruj0KfiGSbS8LVc12LMsWDQzRXJ0qdhN8L8uUigKpfEHRhlaQFY0ib1tnUbNeQ==",
|
"integrity": "sha512-N2brEuAadi0CcdeMXUkhbZB84eskAc8MEX1By6qEchoVywSgXPIjou4rYsl0V3Hj0ZnuGycGCjdNgockbzeWNA==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@humanwhocodes/object-schema": "^1.2.1",
|
"@humanwhocodes/object-schema": "^1.2.1",
|
||||||
|
@ -2826,9 +2829,9 @@
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/@inertiajs/core/node_modules/axios": {
|
"node_modules/@inertiajs/core/node_modules/axios": {
|
||||||
"version": "1.4.0",
|
"version": "1.5.0",
|
||||||
"resolved": "https://registry.npmjs.org/axios/-/axios-1.4.0.tgz",
|
"resolved": "https://registry.npmjs.org/axios/-/axios-1.5.0.tgz",
|
||||||
"integrity": "sha512-S4XCWMEmzvo64T9GfvQDOXgYRDJ/wsSZc7Jvdgx5u1sd0JwsuPLqb3SYmusag+edF6ziyMensPVqLTSc1PiSEA==",
|
"integrity": "sha512-D4DdjDo5CY50Qms0qGQTTw6Q44jl7zRwY7bthds06pUGfChBCTcQs+N743eFWGEd6pRTMd6A+I87aWyFV5wiZQ==",
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"follow-redirects": "^1.15.0",
|
"follow-redirects": "^1.15.0",
|
||||||
"form-data": "^4.0.0",
|
"form-data": "^4.0.0",
|
||||||
|
@ -3757,9 +3760,9 @@
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/@tailwindcss/forms": {
|
"node_modules/@tailwindcss/forms": {
|
||||||
"version": "0.5.5",
|
"version": "0.5.6",
|
||||||
"resolved": "https://registry.npmjs.org/@tailwindcss/forms/-/forms-0.5.5.tgz",
|
"resolved": "https://registry.npmjs.org/@tailwindcss/forms/-/forms-0.5.6.tgz",
|
||||||
"integrity": "sha512-03sXK1DcPt44GZ0Yg6AcAfQln89IKdbE79g2OwoKqBm1ukaadLO2AH3EiB3mXHeQnxa3tzm7eE0x7INXSjbuug==",
|
"integrity": "sha512-Fw+2BJ0tmAwK/w01tEFL5TiaJBX1NLT1/YbWgvm7ws3Qcn11kiXxzNTEQDMs5V3mQemhB56l3u0i9dwdzSQldA==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"mini-svg-data-uri": "^1.2.3"
|
"mini-svg-data-uri": "^1.2.3"
|
||||||
|
@ -3812,6 +3815,25 @@
|
||||||
"integrity": "sha512-mEo1sAde+UCE6b2hxn332f1g1E8WfYRu6p5SvTKr2ZKC1f7gFJXk4h5PyGP9Dt6gCaG8y8XhwnXWC6Iy2cmBng==",
|
"integrity": "sha512-mEo1sAde+UCE6b2hxn332f1g1E8WfYRu6p5SvTKr2ZKC1f7gFJXk4h5PyGP9Dt6gCaG8y8XhwnXWC6Iy2cmBng==",
|
||||||
"dev": true
|
"dev": true
|
||||||
},
|
},
|
||||||
|
"node_modules/@types/clamscan": {
|
||||||
|
"version": "2.0.4",
|
||||||
|
"resolved": "https://registry.npmjs.org/@types/clamscan/-/clamscan-2.0.4.tgz",
|
||||||
|
"integrity": "sha512-NpD+EmE+ZK5WRJOAmeDuSYJIv15BUnc4PxQA+m3QNkutaPBZ7bmLDTvqBu2iDchs7YKQjiEQEwEMvsdwtdtImA==",
|
||||||
|
"dev": true,
|
||||||
|
"dependencies": {
|
||||||
|
"@types/node": "*",
|
||||||
|
"axios": "^0.24.0"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"node_modules/@types/clamscan/node_modules/axios": {
|
||||||
|
"version": "0.24.0",
|
||||||
|
"resolved": "https://registry.npmjs.org/axios/-/axios-0.24.0.tgz",
|
||||||
|
"integrity": "sha512-Q6cWsys88HoPgAaFAVUb0WpPk0O8iTeisR9IMqy9G8AbO4NlpVknrnQS03zzF9PGAWgO3cgletO3VjV/P7VztA==",
|
||||||
|
"dev": true,
|
||||||
|
"dependencies": {
|
||||||
|
"follow-redirects": "^1.14.4"
|
||||||
|
}
|
||||||
|
},
|
||||||
"node_modules/@types/connect": {
|
"node_modules/@types/connect": {
|
||||||
"version": "3.4.35",
|
"version": "3.4.35",
|
||||||
"resolved": "https://registry.npmjs.org/@types/connect/-/connect-3.4.35.tgz",
|
"resolved": "https://registry.npmjs.org/@types/connect/-/connect-3.4.35.tgz",
|
||||||
|
@ -3972,9 +3994,9 @@
|
||||||
"dev": true
|
"dev": true
|
||||||
},
|
},
|
||||||
"node_modules/@types/leaflet": {
|
"node_modules/@types/leaflet": {
|
||||||
"version": "1.9.3",
|
"version": "1.9.4",
|
||||||
"resolved": "https://registry.npmjs.org/@types/leaflet/-/leaflet-1.9.3.tgz",
|
"resolved": "https://registry.npmjs.org/@types/leaflet/-/leaflet-1.9.4.tgz",
|
||||||
"integrity": "sha512-Caa1lYOgKVqDkDZVWkto2Z5JtVo09spEaUt2S69LiugbBpoqQu92HYFMGUbYezZbnBkyOxMNPXHSgRrRY5UyIA==",
|
"integrity": "sha512-kfwgQf4eOxoe/tD9CaKQrBKHbc7VpyfJOG5sxsQtkH+ML9xYa8hUC3UMa0wU1pKfciJtO0pU9g9XbWhPo7iBCA==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@types/geojson": "*"
|
"@types/geojson": "*"
|
||||||
|
@ -3987,18 +4009,18 @@
|
||||||
"dev": true
|
"dev": true
|
||||||
},
|
},
|
||||||
"node_modules/@types/lodash-es": {
|
"node_modules/@types/lodash-es": {
|
||||||
"version": "4.17.8",
|
"version": "4.17.9",
|
||||||
"resolved": "https://registry.npmjs.org/@types/lodash-es/-/lodash-es-4.17.8.tgz",
|
"resolved": "https://registry.npmjs.org/@types/lodash-es/-/lodash-es-4.17.9.tgz",
|
||||||
"integrity": "sha512-euY3XQcZmIzSy7YH5+Unb3b2X12Wtk54YWINBvvGQ5SmMvwb11JQskGsfkH/5HXK77Kr8GF0wkVDIxzAisWtog==",
|
"integrity": "sha512-ZTcmhiI3NNU7dEvWLZJkzG6ao49zOIjEgIE0RgV7wbPxU0f2xT3VSAHw2gmst8swH6V0YkLRGp4qPlX/6I90MQ==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@types/lodash": "*"
|
"@types/lodash": "*"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/@types/luxon": {
|
"node_modules/@types/luxon": {
|
||||||
"version": "3.3.1",
|
"version": "3.3.2",
|
||||||
"resolved": "https://registry.npmjs.org/@types/luxon/-/luxon-3.3.1.tgz",
|
"resolved": "https://registry.npmjs.org/@types/luxon/-/luxon-3.3.2.tgz",
|
||||||
"integrity": "sha512-XOS5nBcgEeP2PpcqJHjCWhUCAzGfXIU8ILOSLpx2FhxqMW9KdxgCGXNOEKGVBfveKtIpztHzKK5vSRVLyW/NqA=="
|
"integrity": "sha512-l5cpE57br4BIjK+9BSkFBOsWtwv6J9bJpC7gdXIzZyI0vuKvNTk0wZZrkQxMGsUAuGW9+WMNWF2IJMD7br2yeQ=="
|
||||||
},
|
},
|
||||||
"node_modules/@types/md5": {
|
"node_modules/@types/md5": {
|
||||||
"version": "2.3.2",
|
"version": "2.3.2",
|
||||||
|
@ -4018,9 +4040,9 @@
|
||||||
"dev": true
|
"dev": true
|
||||||
},
|
},
|
||||||
"node_modules/@types/node": {
|
"node_modules/@types/node": {
|
||||||
"version": "20.5.3",
|
"version": "20.5.9",
|
||||||
"resolved": "https://registry.npmjs.org/@types/node/-/node-20.5.3.tgz",
|
"resolved": "https://registry.npmjs.org/@types/node/-/node-20.5.9.tgz",
|
||||||
"integrity": "sha512-ITI7rbWczR8a/S6qjAW7DMqxqFMjjTo61qZVWJ1ubPvbIQsL5D/TvwjYEalM8Kthpe3hTzOGrF2TGbAu2uyqeA=="
|
"integrity": "sha512-PcGNd//40kHAS3sTlzKB9C9XL4K0sTup8nbG5lC14kzEteTNuAFh9u5nA0o5TWnSG2r/JNPRXFVcHJIIeRlmqQ=="
|
||||||
},
|
},
|
||||||
"node_modules/@types/pino": {
|
"node_modules/@types/pino": {
|
||||||
"version": "6.3.12",
|
"version": "6.3.12",
|
||||||
|
@ -4061,9 +4083,9 @@
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/@types/qs": {
|
"node_modules/@types/qs": {
|
||||||
"version": "6.9.7",
|
"version": "6.9.8",
|
||||||
"resolved": "https://registry.npmjs.org/@types/qs/-/qs-6.9.7.tgz",
|
"resolved": "https://registry.npmjs.org/@types/qs/-/qs-6.9.8.tgz",
|
||||||
"integrity": "sha512-FGa1F62FT09qcrueBA6qYTrJPVDzah9a+493+o2PCXsesWHIn27G98TsSMs3WPNbZIEj4+VJf6saSFpvD+3Zsw==",
|
"integrity": "sha512-u95svzDlTysU5xecFNTgfFG5RUWu1A9P0VzgpcIiGZA9iraHOdSzcxMxQ55DyeRaGCSxQi7LxXDI4rzq/MYfdg==",
|
||||||
"dev": true
|
"dev": true
|
||||||
},
|
},
|
||||||
"node_modules/@types/range-parser": {
|
"node_modules/@types/range-parser": {
|
||||||
|
@ -4079,9 +4101,9 @@
|
||||||
"dev": true
|
"dev": true
|
||||||
},
|
},
|
||||||
"node_modules/@types/semver": {
|
"node_modules/@types/semver": {
|
||||||
"version": "7.5.0",
|
"version": "7.5.1",
|
||||||
"resolved": "https://registry.npmjs.org/@types/semver/-/semver-7.5.0.tgz",
|
"resolved": "https://registry.npmjs.org/@types/semver/-/semver-7.5.1.tgz",
|
||||||
"integrity": "sha512-G8hZ6XJiHnuhQKR7ZmysCeJWE08o8T0AXtk5darsCaTVsYZhhgUrq53jizaR2FvsoeCwJhlmwTjkXBY5Pn/ZHw==",
|
"integrity": "sha512-cJRQXpObxfNKkFAZbJl2yjWtJCqELQIdShsogr1d2MilP8dKD9TE/nEKHkJgUNHdGKCQaf9HbIynuV2csLGVLg==",
|
||||||
"dev": true
|
"dev": true
|
||||||
},
|
},
|
||||||
"node_modules/@types/send": {
|
"node_modules/@types/send": {
|
||||||
|
@ -6060,9 +6082,9 @@
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/caniuse-lite": {
|
"node_modules/caniuse-lite": {
|
||||||
"version": "1.0.30001522",
|
"version": "1.0.30001525",
|
||||||
"resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001522.tgz",
|
"resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001525.tgz",
|
||||||
"integrity": "sha512-TKiyTVZxJGhsTszLuzb+6vUZSjVOAhClszBr2Ta2k9IwtNBT/4dzmL6aywt0HCgEZlmwJzXJd8yNiob6HgwTRg==",
|
"integrity": "sha512-/3z+wB4icFt3r0USMwxujAqRvaD/B7rvGTsKhbhSQErVrJvkZCLhgNLJxU8MevahQVH6hCU9FsHdNUFbiwmE7Q==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"funding": [
|
"funding": [
|
||||||
{
|
{
|
||||||
|
@ -6103,9 +6125,9 @@
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/chai": {
|
"node_modules/chai": {
|
||||||
"version": "4.3.7",
|
"version": "4.3.8",
|
||||||
"resolved": "https://registry.npmjs.org/chai/-/chai-4.3.7.tgz",
|
"resolved": "https://registry.npmjs.org/chai/-/chai-4.3.8.tgz",
|
||||||
"integrity": "sha512-HLnAzZ2iupm25PlN0xFreAlBA5zaBSv3og0DdeGA4Ar6h6rJ3A0rolRUKJhSF2V10GZKDgWF/VmAEsNWjCRB+A==",
|
"integrity": "sha512-vX4YvVVtxlfSZ2VecZgFUTU5qPCYsobVI2O9FmwEXBhDigYGQA6jRXCycIs1yJnnWbZ6/+a2zNIF5DfVCcJBFQ==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"assertion-error": "^1.1.0",
|
"assertion-error": "^1.1.0",
|
||||||
|
@ -6171,9 +6193,9 @@
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/chart.js": {
|
"node_modules/chart.js": {
|
||||||
"version": "4.3.3",
|
"version": "4.4.0",
|
||||||
"resolved": "https://registry.npmjs.org/chart.js/-/chart.js-4.3.3.tgz",
|
"resolved": "https://registry.npmjs.org/chart.js/-/chart.js-4.4.0.tgz",
|
||||||
"integrity": "sha512-aTk7pBw+x6sQYhon/NR3ikfUJuym/LdgpTlgZRe2PaEhjUMKBKyNaFCMVRAyTEWYFNO7qRu7iQVqOw/OqzxZxQ==",
|
"integrity": "sha512-vQEj6d+z0dcsKLlQvbKIMYFHd3t8W/7L2vfJIbYcfyPcRx92CsHqECpueN8qVGNlKyDcr5wBrYAYKnfu/9Q1hQ==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@kurkle/color": "^0.3.0"
|
"@kurkle/color": "^0.3.0"
|
||||||
|
@ -6255,6 +6277,14 @@
|
||||||
"node": ">=8"
|
"node": ">=8"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"node_modules/clamscan": {
|
||||||
|
"version": "2.1.2",
|
||||||
|
"resolved": "https://registry.npmjs.org/clamscan/-/clamscan-2.1.2.tgz",
|
||||||
|
"integrity": "sha512-pcovgLHcrg3l/mI51Kuk0kN++07pSZdBTskISw0UFvsm8UXda8oNCm0eLeODxFg85Mz+k+TtSS9+XPlriJ8/Fg==",
|
||||||
|
"engines": {
|
||||||
|
"node": ">=12.0.0"
|
||||||
|
}
|
||||||
|
},
|
||||||
"node_modules/class-utils": {
|
"node_modules/class-utils": {
|
||||||
"version": "0.3.6",
|
"version": "0.3.6",
|
||||||
"resolved": "https://registry.npmjs.org/class-utils/-/class-utils-0.3.6.tgz",
|
"resolved": "https://registry.npmjs.org/class-utils/-/class-utils-0.3.6.tgz",
|
||||||
|
@ -6722,14 +6752,14 @@
|
||||||
"dev": true
|
"dev": true
|
||||||
},
|
},
|
||||||
"node_modules/cosmiconfig": {
|
"node_modules/cosmiconfig": {
|
||||||
"version": "8.2.0",
|
"version": "8.3.3",
|
||||||
"resolved": "https://registry.npmjs.org/cosmiconfig/-/cosmiconfig-8.2.0.tgz",
|
"resolved": "https://registry.npmjs.org/cosmiconfig/-/cosmiconfig-8.3.3.tgz",
|
||||||
"integrity": "sha512-3rTMnFJA1tCOPwRxtgF4wd7Ab2qvDbL8jX+3smjIbS4HlZBagTlpERbdN7iAbWlrfxE3M8c27kTwTawQ7st+OQ==",
|
"integrity": "sha512-/VY+0IvFoE47hwgKHu8feeBFIb1Z1mcJFiLrNwaJpLoLa9qwLVquMGMr2OUwQmhpJDtsSQSasg/TMv1imec9xA==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"import-fresh": "^3.2.1",
|
"import-fresh": "^3.3.0",
|
||||||
"js-yaml": "^4.1.0",
|
"js-yaml": "^4.1.0",
|
||||||
"parse-json": "^5.0.0",
|
"parse-json": "^5.2.0",
|
||||||
"path-type": "^4.0.0"
|
"path-type": "^4.0.0"
|
||||||
},
|
},
|
||||||
"engines": {
|
"engines": {
|
||||||
|
@ -6737,6 +6767,14 @@
|
||||||
},
|
},
|
||||||
"funding": {
|
"funding": {
|
||||||
"url": "https://github.com/sponsors/d-fischer"
|
"url": "https://github.com/sponsors/d-fischer"
|
||||||
|
},
|
||||||
|
"peerDependencies": {
|
||||||
|
"typescript": ">=4.9.5"
|
||||||
|
},
|
||||||
|
"peerDependenciesMeta": {
|
||||||
|
"typescript": {
|
||||||
|
"optional": true
|
||||||
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/cosmiconfig/node_modules/argparse": {
|
"node_modules/cosmiconfig/node_modules/argparse": {
|
||||||
|
@ -6983,9 +7021,9 @@
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/css-minimizer-webpack-plugin/node_modules/jest-worker": {
|
"node_modules/css-minimizer-webpack-plugin/node_modules/jest-worker": {
|
||||||
"version": "29.6.3",
|
"version": "29.6.4",
|
||||||
"resolved": "https://registry.npmjs.org/jest-worker/-/jest-worker-29.6.3.tgz",
|
"resolved": "https://registry.npmjs.org/jest-worker/-/jest-worker-29.6.4.tgz",
|
||||||
"integrity": "sha512-wacANXecZ/GbQakpf2CClrqrlwsYYDSXFd4fIGdL+dXpM2GWoJ+6bhQ7vR3TKi3+gkSfBkjy1/khH/WrYS4Q6g==",
|
"integrity": "sha512-6dpvFV4WjcWbDVGgHTWo/aupl8/LbBx2NSKfiwqf79xC/yeJjKHT1+StcKy/2KTmW16hE68ccKVOtXf+WZGz7Q==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@types/node": "*",
|
"@types/node": "*",
|
||||||
|
@ -7682,9 +7720,9 @@
|
||||||
"dev": true
|
"dev": true
|
||||||
},
|
},
|
||||||
"node_modules/dns-packet": {
|
"node_modules/dns-packet": {
|
||||||
"version": "5.6.0",
|
"version": "5.6.1",
|
||||||
"resolved": "https://registry.npmjs.org/dns-packet/-/dns-packet-5.6.0.tgz",
|
"resolved": "https://registry.npmjs.org/dns-packet/-/dns-packet-5.6.1.tgz",
|
||||||
"integrity": "sha512-rza3UH1LwdHh9qyPXp8lkwpjSNk/AMD3dPytUoRoqnypDUhY0xvbdmVhWOfxO68frEfV9BU8V12Ez7ZsHGZpCQ==",
|
"integrity": "sha512-l4gcSouhcgIKRvyy99RNVOgxXiicE+2jZoNmaNmZ6JXiGajBOJAesk1OBlJuM5k2c+eudGdLxDqXuPCKIj6kpw==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@leichtgewicht/ip-codec": "^2.0.1"
|
"@leichtgewicht/ip-codec": "^2.0.1"
|
||||||
|
@ -7929,9 +7967,9 @@
|
||||||
"integrity": "sha512-WMwm9LhRUo+WUaRN+vRuETqG89IgZphVSNkdFgeb6sS/E4OrDIN7t48CAewSHXc6C8lefD8KKfr5vY61brQlow=="
|
"integrity": "sha512-WMwm9LhRUo+WUaRN+vRuETqG89IgZphVSNkdFgeb6sS/E4OrDIN7t48CAewSHXc6C8lefD8KKfr5vY61brQlow=="
|
||||||
},
|
},
|
||||||
"node_modules/electron-to-chromium": {
|
"node_modules/electron-to-chromium": {
|
||||||
"version": "1.4.499",
|
"version": "1.4.508",
|
||||||
"resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.4.499.tgz",
|
"resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.4.508.tgz",
|
||||||
"integrity": "sha512-0NmjlYBLKVHva4GABWAaHuPJolnDuL0AhV3h1hES6rcLCWEIbRL6/8TghfsVwkx6TEroQVdliX7+aLysUpKvjw==",
|
"integrity": "sha512-FFa8QKjQK/A5QuFr2167myhMesGrhlOBD+3cYNxO9/S4XzHEXesyTD/1/xF644gC8buFPz3ca6G1LOQD0tZrrg==",
|
||||||
"dev": true
|
"dev": true
|
||||||
},
|
},
|
||||||
"node_modules/emittery": {
|
"node_modules/emittery": {
|
||||||
|
@ -8080,15 +8118,15 @@
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/eslint": {
|
"node_modules/eslint": {
|
||||||
"version": "8.47.0",
|
"version": "8.48.0",
|
||||||
"resolved": "https://registry.npmjs.org/eslint/-/eslint-8.47.0.tgz",
|
"resolved": "https://registry.npmjs.org/eslint/-/eslint-8.48.0.tgz",
|
||||||
"integrity": "sha512-spUQWrdPt+pRVP1TTJLmfRNJJHHZryFmptzcafwSvHsceV81djHOdnEeDmkdotZyLNjDhrOasNK8nikkoG1O8Q==",
|
"integrity": "sha512-sb6DLeIuRXxeM1YljSe1KEx9/YYeZFQWcV8Rq9HfigmdDEugjLEVEa1ozDjL6YDjBpQHPJxJzze+alxi4T3OLg==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@eslint-community/eslint-utils": "^4.2.0",
|
"@eslint-community/eslint-utils": "^4.2.0",
|
||||||
"@eslint-community/regexpp": "^4.6.1",
|
"@eslint-community/regexpp": "^4.6.1",
|
||||||
"@eslint/eslintrc": "^2.1.2",
|
"@eslint/eslintrc": "^2.1.2",
|
||||||
"@eslint/js": "^8.47.0",
|
"@eslint/js": "8.48.0",
|
||||||
"@humanwhocodes/config-array": "^0.11.10",
|
"@humanwhocodes/config-array": "^0.11.10",
|
||||||
"@humanwhocodes/module-importer": "^1.0.1",
|
"@humanwhocodes/module-importer": "^1.0.1",
|
||||||
"@nodelib/fs.walk": "^1.2.8",
|
"@nodelib/fs.walk": "^1.2.8",
|
||||||
|
@ -8971,16 +9009,17 @@
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/flat-cache": {
|
"node_modules/flat-cache": {
|
||||||
"version": "3.0.4",
|
"version": "3.1.0",
|
||||||
"resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-3.0.4.tgz",
|
"resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-3.1.0.tgz",
|
||||||
"integrity": "sha512-dm9s5Pw7Jc0GvMYbshN6zchCA9RgQlzzEZX3vylR9IqFfS8XciblUXOKfW6SiuJ0e13eDYZoZV5wdrev7P3Nwg==",
|
"integrity": "sha512-OHx4Qwrrt0E4jEIcI5/Xb+f+QmJYNj2rrK8wiIdQOIrB9WrrJL8cjZvXdXuBTkkEwEqLycb5BeZDV1o2i9bTew==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"flatted": "^3.1.0",
|
"flatted": "^3.2.7",
|
||||||
|
"keyv": "^4.5.3",
|
||||||
"rimraf": "^3.0.2"
|
"rimraf": "^3.0.2"
|
||||||
},
|
},
|
||||||
"engines": {
|
"engines": {
|
||||||
"node": "^10.12.0 || >=12.0.0"
|
"node": ">=12.0.0"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/flat-cache/node_modules/rimraf": {
|
"node_modules/flat-cache/node_modules/rimraf": {
|
||||||
|
@ -9082,16 +9121,16 @@
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/fraction.js": {
|
"node_modules/fraction.js": {
|
||||||
"version": "4.2.1",
|
"version": "4.3.6",
|
||||||
"resolved": "https://registry.npmjs.org/fraction.js/-/fraction.js-4.2.1.tgz",
|
"resolved": "https://registry.npmjs.org/fraction.js/-/fraction.js-4.3.6.tgz",
|
||||||
"integrity": "sha512-/KxoyCnPM0GwYI4NN0Iag38Tqt+od3/mLuguepLgCAKPn0ZhC544nssAW0tG2/00zXEYl9W+7hwAIpLHo6Oc7Q==",
|
"integrity": "sha512-n2aZ9tNfYDwaHhvFTkhFErqOMIb8uyzSQ+vGJBjZyanAKZVbGUQ1sngfk9FdkBw7G26O7AgNjLcecLffD1c7eg==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"engines": {
|
"engines": {
|
||||||
"node": "*"
|
"node": "*"
|
||||||
},
|
},
|
||||||
"funding": {
|
"funding": {
|
||||||
"type": "patreon",
|
"type": "patreon",
|
||||||
"url": "https://www.patreon.com/infusion"
|
"url": "https://github.com/sponsors/rawify"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/fragment-cache": {
|
"node_modules/fragment-cache": {
|
||||||
|
@ -10487,9 +10526,9 @@
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/jest-diff": {
|
"node_modules/jest-diff": {
|
||||||
"version": "29.6.3",
|
"version": "29.6.4",
|
||||||
"resolved": "https://registry.npmjs.org/jest-diff/-/jest-diff-29.6.3.tgz",
|
"resolved": "https://registry.npmjs.org/jest-diff/-/jest-diff-29.6.4.tgz",
|
||||||
"integrity": "sha512-3sw+AdWnwH9sSNohMRKA7JiYUJSRr/WS6+sEFfBuhxU5V5GlEVKfvUn8JuMHE0wqKowemR1C2aHy8VtXbaV8dQ==",
|
"integrity": "sha512-9F48UxR9e4XOEZvoUXEHSWY4qC4zERJaOfrbBg9JpbJOO43R1vN76REt/aMGZoY6GD5g84nnJiBIVlscegefpw==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"chalk": "^4.0.0",
|
"chalk": "^4.0.0",
|
||||||
|
@ -10925,6 +10964,12 @@
|
||||||
"node": ">=4"
|
"node": ">=4"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"node_modules/json-buffer": {
|
||||||
|
"version": "3.0.1",
|
||||||
|
"resolved": "https://registry.npmjs.org/json-buffer/-/json-buffer-3.0.1.tgz",
|
||||||
|
"integrity": "sha512-4bV5BfR2mqfQTJm+V5tPPdf+ZpuhiIvTuAB5g8kcrXOZpTT/QwwVRWBywX1ozr6lEuPdbHxwaJlm9G6mI2sfSQ==",
|
||||||
|
"dev": true
|
||||||
|
},
|
||||||
"node_modules/json-parse-even-better-errors": {
|
"node_modules/json-parse-even-better-errors": {
|
||||||
"version": "2.3.1",
|
"version": "2.3.1",
|
||||||
"resolved": "https://registry.npmjs.org/json-parse-even-better-errors/-/json-parse-even-better-errors-2.3.1.tgz",
|
"resolved": "https://registry.npmjs.org/json-parse-even-better-errors/-/json-parse-even-better-errors-2.3.1.tgz",
|
||||||
|
@ -11005,6 +11050,15 @@
|
||||||
"node": ">=8"
|
"node": ">=8"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"node_modules/keyv": {
|
||||||
|
"version": "4.5.3",
|
||||||
|
"resolved": "https://registry.npmjs.org/keyv/-/keyv-4.5.3.tgz",
|
||||||
|
"integrity": "sha512-QCiSav9WaX1PgETJ+SpNnx2PRRapJ/oRSXM4VO5OGYGSjrxbKPVFVhB3l2OCbLCk329N8qyAtsJjSjvVBWzEug==",
|
||||||
|
"dev": true,
|
||||||
|
"dependencies": {
|
||||||
|
"json-buffer": "3.0.1"
|
||||||
|
}
|
||||||
|
},
|
||||||
"node_modules/kind-of": {
|
"node_modules/kind-of": {
|
||||||
"version": "6.0.3",
|
"version": "6.0.3",
|
||||||
"resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.3.tgz",
|
"resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.3.tgz",
|
||||||
|
@ -11292,9 +11346,9 @@
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/luxon": {
|
"node_modules/luxon": {
|
||||||
"version": "3.4.1",
|
"version": "3.4.2",
|
||||||
"resolved": "https://registry.npmjs.org/luxon/-/luxon-3.4.1.tgz",
|
"resolved": "https://registry.npmjs.org/luxon/-/luxon-3.4.2.tgz",
|
||||||
"integrity": "sha512-2USspxOCXWGIKHwuQ9XElxPPYrDOJHDQ5DQ870CoD+CxJbBnRDIBCfhioUJJjct7BKOy80Ia8cVstIcIMb/0+Q==",
|
"integrity": "sha512-uBoAVCVcajsrqy3pv7eo5jEUz1oeLmCcnMv8n4AJpT5hbpN9lUssAXibNElpbLce3Mhm9dyBzwYLs9zctM/0tA==",
|
||||||
"engines": {
|
"engines": {
|
||||||
"node": ">=12"
|
"node": ">=12"
|
||||||
}
|
}
|
||||||
|
@ -12829,9 +12883,9 @@
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/pinia/node_modules/vue-demi": {
|
"node_modules/pinia/node_modules/vue-demi": {
|
||||||
"version": "0.14.5",
|
"version": "0.14.6",
|
||||||
"resolved": "https://registry.npmjs.org/vue-demi/-/vue-demi-0.14.5.tgz",
|
"resolved": "https://registry.npmjs.org/vue-demi/-/vue-demi-0.14.6.tgz",
|
||||||
"integrity": "sha512-o9NUVpl/YlsGJ7t+xuqJKx8EBGf1quRhCiT6D/J0pfwmk9zUwYkC7yrF4SZCe6fETvSM3UNL2edcbYrSyc4QHA==",
|
"integrity": "sha512-8QA7wrYSHKaYgUxDA5ZC24w+eHm3sYCbp0EzcDwKqN3p6HqtTCGR/GVsPyZW92unff4UlcSh++lmqDWN3ZIq4w==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"hasInstallScript": true,
|
"hasInstallScript": true,
|
||||||
"bin": {
|
"bin": {
|
||||||
|
@ -12893,9 +12947,9 @@
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/pino-abstract-transport": {
|
"node_modules/pino-abstract-transport": {
|
||||||
"version": "1.0.0",
|
"version": "1.1.0",
|
||||||
"resolved": "https://registry.npmjs.org/pino-abstract-transport/-/pino-abstract-transport-1.0.0.tgz",
|
"resolved": "https://registry.npmjs.org/pino-abstract-transport/-/pino-abstract-transport-1.1.0.tgz",
|
||||||
"integrity": "sha512-c7vo5OpW4wIS42hUVcT5REsL8ZljsUfBjqV/e2sFxmFEFZiq1XLUp5EYLtuDH6PEHq9W1egWqRbnLUP5FuZmOA==",
|
"integrity": "sha512-lsleG3/2a/JIWUtf9Q5gUNErBqwIu1tUKTT3dUzaf5DySw9ra1wcqKjJjLX1VTY64Wk1eEOYsVGSaGfCK85ekA==",
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"readable-stream": "^4.0.0",
|
"readable-stream": "^4.0.0",
|
||||||
"split2": "^4.0.0"
|
"split2": "^4.0.0"
|
||||||
|
@ -13116,9 +13170,9 @@
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/postcss": {
|
"node_modules/postcss": {
|
||||||
"version": "8.4.28",
|
"version": "8.4.29",
|
||||||
"resolved": "https://registry.npmjs.org/postcss/-/postcss-8.4.28.tgz",
|
"resolved": "https://registry.npmjs.org/postcss/-/postcss-8.4.29.tgz",
|
||||||
"integrity": "sha512-Z7V5j0cq8oEKyejIKfpD8b4eBy9cwW2JWPk0+fB1HOAMsfHbnAXLLS+PfVWlzMSLQaWttKDt607I0XHmpE67Vw==",
|
"integrity": "sha512-cbI+jaqIeu/VGqXEarWkRCCffhjgXc0qjBtXpqJhTBohMUjUQnbBr0xqX3vEKudc4iviTewcJo5ajcec5+wdJw==",
|
||||||
"funding": [
|
"funding": [
|
||||||
{
|
{
|
||||||
"type": "opencollective",
|
"type": "opencollective",
|
||||||
|
@ -13778,9 +13832,9 @@
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/prettier": {
|
"node_modules/prettier": {
|
||||||
"version": "3.0.2",
|
"version": "3.0.3",
|
||||||
"resolved": "https://registry.npmjs.org/prettier/-/prettier-3.0.2.tgz",
|
"resolved": "https://registry.npmjs.org/prettier/-/prettier-3.0.3.tgz",
|
||||||
"integrity": "sha512-o2YR9qtniXvwEZlOKbveKfDQVyqxbEIWn48Z8m3ZJjBjcCmUy3xZGIv+7AkaeuaTr6yPXJjwv07ZWlsWbEy1rQ==",
|
"integrity": "sha512-L/4pUDMxcNa8R/EthV08Zt42WBO4h1rarVtK0K+QJG0X187OLo7l699jWw0GKuwzkPQ//jMFA/8Xm6Fh3J/DAg==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"bin": {
|
"bin": {
|
||||||
"prettier": "bin/prettier.cjs"
|
"prettier": "bin/prettier.cjs"
|
||||||
|
@ -15908,9 +15962,9 @@
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/terser": {
|
"node_modules/terser": {
|
||||||
"version": "5.19.2",
|
"version": "5.19.3",
|
||||||
"resolved": "https://registry.npmjs.org/terser/-/terser-5.19.2.tgz",
|
"resolved": "https://registry.npmjs.org/terser/-/terser-5.19.3.tgz",
|
||||||
"integrity": "sha512-qC5+dmecKJA4cpYxRa5aVkKehYsQKc+AHeKl0Oe62aYjBL8ZA33tTljktDHJSaxxMnbI5ZYw+o/S2DxxLu8OfA==",
|
"integrity": "sha512-pQzJ9UJzM0IgmT4FAtYI6+VqFf0lj/to58AV0Xfgg0Up37RyPG7Al+1cepC6/BVuAxR9oNb41/DL4DEoHJvTdg==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@jridgewell/source-map": "^0.3.3",
|
"@jridgewell/source-map": "^0.3.3",
|
||||||
|
@ -16372,9 +16426,9 @@
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/typescript": {
|
"node_modules/typescript": {
|
||||||
"version": "5.1.6",
|
"version": "5.2.2",
|
||||||
"resolved": "https://registry.npmjs.org/typescript/-/typescript-5.1.6.tgz",
|
"resolved": "https://registry.npmjs.org/typescript/-/typescript-5.2.2.tgz",
|
||||||
"integrity": "sha512-zaWCozRZ6DLEWAWFrVDz1H6FVXzUSfTy5FUMWsQlU8Ym5JP9eO4xkTIROFCQvhQf61z6O/G6ugw3SgAnvvm+HA==",
|
"integrity": "sha512-mI4WrpHsbCIcwT9cF4FZvr80QUeKvsUsUvKDoR+X/7XHQH98xYD8YHZg7ANtz2GtZt/CBq2QJ0thkGJMHfqc1w==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"bin": {
|
"bin": {
|
||||||
"tsc": "bin/tsc",
|
"tsc": "bin/tsc",
|
||||||
|
@ -17430,9 +17484,9 @@
|
||||||
"dev": true
|
"dev": true
|
||||||
},
|
},
|
||||||
"node_modules/yaml": {
|
"node_modules/yaml": {
|
||||||
"version": "2.3.1",
|
"version": "2.3.2",
|
||||||
"resolved": "https://registry.npmjs.org/yaml/-/yaml-2.3.1.tgz",
|
"resolved": "https://registry.npmjs.org/yaml/-/yaml-2.3.2.tgz",
|
||||||
"integrity": "sha512-2eHWfjaoXgTBC2jNM1LRef62VQa0umtvRiDSk6HSzW7RvS5YtkabJrwYLLEKWBc8a5U2PTSCs+dJjUTJdlHsWQ==",
|
"integrity": "sha512-N/lyzTPaJasoDmfV7YTrYCI0G/3ivm/9wdG0aHuheKowWQwGTsK0Eoiw6utmzAnI6pkJa0DUVygvp3spqqEKXg==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"engines": {
|
"engines": {
|
||||||
"node": ">= 14"
|
"node": ">= 14"
|
||||||
|
|
|
@ -31,6 +31,7 @@
|
||||||
"@mdi/js": "^7.1.96",
|
"@mdi/js": "^7.1.96",
|
||||||
"@symfony/webpack-encore": "^4.2.0",
|
"@symfony/webpack-encore": "^4.2.0",
|
||||||
"@tailwindcss/forms": "^0.5.2",
|
"@tailwindcss/forms": "^0.5.2",
|
||||||
|
"@types/clamscan": "^2.0.4",
|
||||||
"@types/leaflet": "^1.9.3",
|
"@types/leaflet": "^1.9.3",
|
||||||
"@types/node": "^20.1.1",
|
"@types/node": "^20.1.1",
|
||||||
"@types/proxy-addr": "^2.0.0",
|
"@types/proxy-addr": "^2.0.0",
|
||||||
|
@ -76,6 +77,7 @@
|
||||||
"@inertiajs/inertia": "^0.11.1",
|
"@inertiajs/inertia": "^0.11.1",
|
||||||
"@inertiajs/vue3": "^1.0.0",
|
"@inertiajs/vue3": "^1.0.0",
|
||||||
"bcryptjs": "^2.4.3",
|
"bcryptjs": "^2.4.3",
|
||||||
|
"clamscan": "^2.1.2",
|
||||||
"crypto": "^1.0.1",
|
"crypto": "^1.0.1",
|
||||||
"dayjs": "^1.11.7",
|
"dayjs": "^1.11.7",
|
||||||
"http-status-codes": "^2.2.0",
|
"http-status-codes": "^2.2.0",
|
||||||
|
|
|
@ -8,10 +8,10 @@
|
||||||
"assets/fonts/inter-latin-400-normal.woff2": "http://localhost:8080/assets/fonts/inter-latin-400-normal.be7cb18d.woff2",
|
"assets/fonts/inter-latin-400-normal.woff2": "http://localhost:8080/assets/fonts/inter-latin-400-normal.be7cb18d.woff2",
|
||||||
"assets/fonts/archivo-black-latin-ext-400-normal.woff2": "http://localhost:8080/assets/fonts/archivo-black-latin-ext-400-normal.21761451.woff2",
|
"assets/fonts/archivo-black-latin-ext-400-normal.woff2": "http://localhost:8080/assets/fonts/archivo-black-latin-ext-400-normal.21761451.woff2",
|
||||||
"assets/fonts/inter-cyrillic-ext-400-normal.woff": "http://localhost:8080/assets/fonts/inter-cyrillic-ext-400-normal.3c63e274.woff",
|
"assets/fonts/inter-cyrillic-ext-400-normal.woff": "http://localhost:8080/assets/fonts/inter-cyrillic-ext-400-normal.3c63e274.woff",
|
||||||
"assets/fonts/archivo-black-latin-400-normal.woff": "http://localhost:8080/assets/fonts/archivo-black-latin-400-normal.583e4fc9.woff",
|
"assets/fonts/archivo-black-latin-400-normal.woff": "http://localhost:8080/assets/fonts/archivo-black-latin-400-normal.58a301a6.woff",
|
||||||
"assets/fonts/inter-greek-400-normal.woff": "http://localhost:8080/assets/fonts/inter-greek-400-normal.b31b8612.woff",
|
"assets/fonts/inter-greek-400-normal.woff": "http://localhost:8080/assets/fonts/inter-greek-400-normal.b31b8612.woff",
|
||||||
"assets/fonts/inter-cyrillic-ext-400-normal.woff2": "http://localhost:8080/assets/fonts/inter-cyrillic-ext-400-normal.fcc125c4.woff2",
|
"assets/fonts/inter-cyrillic-ext-400-normal.woff2": "http://localhost:8080/assets/fonts/inter-cyrillic-ext-400-normal.fcc125c4.woff2",
|
||||||
"assets/fonts/archivo-black-latin-ext-400-normal.woff": "http://localhost:8080/assets/fonts/archivo-black-latin-ext-400-normal.ce39b04f.woff",
|
"assets/fonts/archivo-black-latin-ext-400-normal.woff": "http://localhost:8080/assets/fonts/archivo-black-latin-ext-400-normal.5ab5ba92.woff",
|
||||||
"assets/fonts/inter-cyrillic-400-normal.woff": "http://localhost:8080/assets/fonts/inter-cyrillic-400-normal.3862a5ab.woff",
|
"assets/fonts/inter-cyrillic-400-normal.woff": "http://localhost:8080/assets/fonts/inter-cyrillic-400-normal.3862a5ab.woff",
|
||||||
"assets/fonts/inter-greek-400-normal.woff2": "http://localhost:8080/assets/fonts/inter-greek-400-normal.0278a49f.woff2",
|
"assets/fonts/inter-greek-400-normal.woff2": "http://localhost:8080/assets/fonts/inter-greek-400-normal.0278a49f.woff2",
|
||||||
"assets/fonts/inter-greek-ext-400-normal.woff": "http://localhost:8080/assets/fonts/inter-greek-ext-400-normal.61350b97.woff",
|
"assets/fonts/inter-greek-ext-400-normal.woff": "http://localhost:8080/assets/fonts/inter-greek-ext-400-normal.61350b97.woff",
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
<script setup lang="ts">
|
<script setup lang="ts">
|
||||||
import { Head, useForm, usePage } from '@inertiajs/vue3';
|
import { Head, useForm, usePage } from '@inertiajs/vue3';
|
||||||
import { ref, watch, computed, ComputedRef } from 'vue';
|
import { ref, watch, computed, ComputedRef } from 'vue';
|
||||||
|
import FormValidationErrors from '@/Components/FormValidationErrors.vue';
|
||||||
import { Dataset, Description, Title, Subject } from '@/Dataset';
|
import { Dataset, Description, Title, Subject } from '@/Dataset';
|
||||||
import {
|
import {
|
||||||
mdiDatabasePlus,
|
mdiDatabasePlus,
|
||||||
|
@ -456,6 +456,7 @@ Removes a selected keyword
|
||||||
<NotificationBar v-if="flash.message" color="success" :icon="mdiAlertBoxOutline">
|
<NotificationBar v-if="flash.message" color="success" :icon="mdiAlertBoxOutline">
|
||||||
{{ flash.message }}
|
{{ flash.message }}
|
||||||
</NotificationBar>
|
</NotificationBar>
|
||||||
|
<FormValidationErrors v-bind:errors="errors" />
|
||||||
|
|
||||||
<CardBox>
|
<CardBox>
|
||||||
<div class="mx-4 p-4">
|
<div class="mx-4 p-4">
|
||||||
|
|
|
@ -12,6 +12,10 @@ Route.group(() => {
|
||||||
// Route.get("author/:id", "TodosController.show");
|
// Route.get("author/:id", "TodosController.show");
|
||||||
// Route.put("author/update", "TodosController.update");
|
// Route.put("author/update", "TodosController.update");
|
||||||
// Route.post("author", "TodosController.store");
|
// Route.post("author", "TodosController.store");
|
||||||
|
Route.get('/dataset', 'DatasetController.findAll').as('dataset.findAll');
|
||||||
|
Route.get('/dataset/:publish_id', 'DatasetController.findOne').as('dataset.findOne');
|
||||||
|
Route.get('/sitelinks/:year', 'HomeController.findDocumentsPerYear');
|
||||||
|
Route.get('/years', 'HomeController.findYears');
|
||||||
});
|
});
|
||||||
// .middleware("auth:api");
|
// .middleware("auth:api");
|
||||||
})
|
})
|
||||||
|
|
|
@ -72,3 +72,69 @@ validator.rule(
|
||||||
// }
|
// }
|
||||||
},
|
},
|
||||||
);
|
);
|
||||||
|
|
||||||
|
validator.rule('fileExtension', async (value, [extensions], { pointer, arrayExpressionPointer, errorReporter }) => {
|
||||||
|
const allowedExtensions = extensions.map((ext: string) => ext.toLowerCase());
|
||||||
|
const uploadedFile = value;
|
||||||
|
|
||||||
|
if (!uploadedFile) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
const extension = uploadedFile.extname.toLowerCase().replace('.', '');
|
||||||
|
|
||||||
|
if (!allowedExtensions.includes(extension)) {
|
||||||
|
errorReporter.report(
|
||||||
|
pointer,
|
||||||
|
'fileExtension',
|
||||||
|
'Invalid file extension. Only {{ extensions }} files are allowed.',
|
||||||
|
arrayExpressionPointer,
|
||||||
|
);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
// validator.rule(
|
||||||
|
// 'clamavScan',
|
||||||
|
// (value, [field], { root, tip, pointer, arrayExpressionPointer, errorReporter }) => {
|
||||||
|
// if (typeof value !== 'object') {
|
||||||
|
// return;
|
||||||
|
// }
|
||||||
|
// const uploadedFile = validator.helpers.getFieldValue(field, root, tip);
|
||||||
|
// // return rules.file({}, [
|
||||||
|
// // async (file) => {
|
||||||
|
// // const clamdhost = process.env['CLAMD_HOST'] ?? '127.0.0.1';
|
||||||
|
// // const clamdport = Number(process.env['CLAMD_PORT']) ?? '3310';
|
||||||
|
// // try {
|
||||||
|
// // var isInfected = await scanFileForViruses(file.tmpPath, clamdhost, clamdport);
|
||||||
|
// // } catch (error) {
|
||||||
|
// // throw new Error(`${pointer}: ${error.message}`);
|
||||||
|
// // }
|
||||||
|
// // },
|
||||||
|
// // ]);
|
||||||
|
// });
|
||||||
|
|
||||||
|
// async function scanFileForViruses(filePath, host, port): Promise<boolean> {
|
||||||
|
// // const clamscan = await (new ClamScan().init());
|
||||||
|
// const opts: ClamScan.Options = {
|
||||||
|
// preference: 'clamdscan',
|
||||||
|
// clamdscan: {
|
||||||
|
// active: true,
|
||||||
|
// host,
|
||||||
|
// port,
|
||||||
|
// multiscan: true,
|
||||||
|
// },
|
||||||
|
// };
|
||||||
|
// const clamscan = await new ClamScan().init(opts);
|
||||||
|
|
||||||
|
// return new Promise((resolve, reject) => {
|
||||||
|
// clamscan.isInfected(filePath, (err, file, isInfected: boolean) => {
|
||||||
|
// if (err) {
|
||||||
|
// reject(err);
|
||||||
|
// } else if (isInfected) {
|
||||||
|
// reject(new Error(`File ${file} is infected!`));
|
||||||
|
// } else {
|
||||||
|
// resolve(isInfected);
|
||||||
|
// }
|
||||||
|
// });
|
||||||
|
// });
|
||||||
|
// }
|
||||||
|
|
|
@ -19,13 +19,13 @@
|
||||||
"outDir": "build",
|
"outDir": "build",
|
||||||
"rootDir": "./",
|
"rootDir": "./",
|
||||||
"sourceMap": true,
|
"sourceMap": true,
|
||||||
"moduleResolution": "node", //neu
|
// "moduleResolution": "node", //neu
|
||||||
"experimentalDecorators": true, //neu
|
"experimentalDecorators": true, //neu
|
||||||
"strictPropertyInitialization": false, //neu
|
"strictPropertyInitialization": false, //neu
|
||||||
// Target latest language version 'esnext' of ECMAScript or minimal 'es6'.
|
// Target latest language version 'esnext' of ECMAScript or minimal 'es6'.
|
||||||
"target": "esnext", //neu
|
"target": "esnext", //neu
|
||||||
//what module code is generated
|
//what module code is generated
|
||||||
"module": "NodeNext", //neu
|
// "module": "NodeNext", //neu
|
||||||
"skipLibCheck": true, //neu
|
"skipLibCheck": true, //neu
|
||||||
"esModuleInterop": true, //neu
|
"esModuleInterop": true, //neu
|
||||||
"allowSyntheticDefaultImports": true, //neu,
|
"allowSyntheticDefaultImports": true, //neu,
|
||||||
|
|
Loading…
Reference in New Issue
Block a user