mirror of
https://github.com/laurent22/joplin.git
synced 2024-12-24 10:27:10 +02:00
45 lines
1.9 KiB
TypeScript
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 });
|
|
}
|