1
0
mirror of https://github.com/laurent22/joplin.git synced 2025-01-02 12:47:41 +02:00
joplin/packages/lib/services/rest/routes/search.ts
2024-04-27 12:11:40 +01:00

45 lines
1.9 KiB
TypeScript

import BaseModel, { ModelType } from '../../../BaseModel';
import { Request } from '../Api';
import defaultLoadOptions from '../utils/defaultLoadOptions';
import { ErrorBadRequest, ErrorMethodNotAllowed } from '../utils/errors';
import requestFields from '../utils/requestFields';
import collectionToPaginatedResults from '../utils/collectionToPaginatedResults';
import BaseItem from '../../../models/BaseItem';
import { NoteEntity } from '../../database/types';
import SearchEngineUtils, { NotesForQueryOptions } from '../../search/SearchEngineUtils';
export default async function(request: Request) {
if (request.method !== 'GET') throw new ErrorMethodNotAllowed();
const query = request.query.query;
if (!query) throw new ErrorBadRequest('Missing "query" parameter');
const modelType = request.query.type ? BaseModel.modelNameToType(request.query.type) : BaseModel.TYPE_NOTE;
let results: NoteEntity[] = [];
if (modelType !== BaseItem.TYPE_NOTE) {
const ModelClass = BaseItem.getClassByItemType(modelType);
// eslint-disable-next-line @typescript-eslint/no-explicit-any -- Old code before rule was applied
const options: any = {};
const fields = requestFields(request, modelType);
if (fields.length) options.fields = fields;
const sqlQueryPart = query.replace(/\*/g, '%');
options.where = 'title LIKE ?';
options.whereParams = [sqlQueryPart];
options.caseInsensitive = true;
results = await ModelClass.all(options);
} else {
const options: NotesForQueryOptions = {
...defaultLoadOptions(request, ModelType.Note),
appendWildCards: true,
};
results = (await SearchEngineUtils.notesForQuery(query, false, options)).notes;
}
// We do not sort the results if the "order_by" query parameter is not specified, because the
// search engine has already sorted them in order of relevance.
// https://github.com/laurent22/joplin/issues/10088
return collectionToPaginatedResults(modelType, results, request, { sort: !!request.query.order_by });
}