mirror of
https://github.com/hexastack/hexabot
synced 2025-06-26 18:27:28 +00:00
204 lines
5.2 KiB
TypeScript
204 lines
5.2 KiB
TypeScript
/*
|
|
* Copyright © 2024 Hexastack. All rights reserved.
|
|
*
|
|
* Licensed under the GNU Affero General Public License v3.0 (AGPLv3) with the following additional terms:
|
|
* 1. The name "Hexabot" is a trademark of Hexastack. You may not use this name in derivative works without express written permission.
|
|
* 2. All derivative works must include clear attribution to the original creator and software, Hexastack and Hexabot, in a prominent location (e.g., in the software's "About" section, documentation, and README file).
|
|
*/
|
|
|
|
/**
|
|
* @file NlpAdapter is an abstract class for define an NLP provider adapter
|
|
* @author Hexastack <contact@hexastack.com>
|
|
*/
|
|
|
|
/**
|
|
* @module Services/NLP
|
|
*
|
|
* NlpAdapter is an abstract class from which each NLP provider adapter should extend from.
|
|
*/
|
|
|
|
import { v4 as uuidv4 } from 'uuid';
|
|
|
|
import { LoggerService } from '@/logger/logger.service';
|
|
import {
|
|
NlpEntity,
|
|
NlpEntityDocument,
|
|
NlpEntityFull,
|
|
} from '@/nlp/schemas/nlp-entity.schema';
|
|
import { NlpSample, NlpSampleFull } from '@/nlp/schemas/nlp-sample.schema';
|
|
import {
|
|
NlpValue,
|
|
NlpValueDocument,
|
|
NlpValueFull,
|
|
} from '@/nlp/schemas/nlp-value.schema';
|
|
import { Settings } from '@/setting/schemas/types';
|
|
|
|
import { NlpEntityService } from '../services/nlp-entity.service';
|
|
import { NlpSampleService } from '../services/nlp-sample.service';
|
|
import { NlpService } from '../services/nlp.service';
|
|
|
|
import { Nlp } from './types';
|
|
|
|
export default abstract class BaseNlpHelper {
|
|
protected settings: Settings['nlp_settings'];
|
|
|
|
constructor(
|
|
protected readonly logger: LoggerService,
|
|
protected readonly nlpService: NlpService,
|
|
protected readonly nlpSampleService: NlpSampleService,
|
|
protected readonly nlpEntityService: NlpEntityService,
|
|
) {}
|
|
|
|
setSettings(settings: Settings['nlp_settings']) {
|
|
this.settings = settings;
|
|
}
|
|
|
|
/**
|
|
* Returns the helper's name
|
|
*
|
|
* @returns Helper's name
|
|
*/
|
|
abstract getName(): string;
|
|
|
|
/**
|
|
* Updates an entity
|
|
*
|
|
* @param entity - The updated entity
|
|
*
|
|
* @returns The updated entity otherwise an error
|
|
*/
|
|
async updateEntity(entity: NlpEntity): Promise<NlpEntity> {
|
|
return entity;
|
|
}
|
|
|
|
/**
|
|
* Adds an entity
|
|
*
|
|
* @param entity - The entity to add
|
|
* @returns The added entity otherwise an error
|
|
*/
|
|
addEntity(_entity: NlpEntityDocument): Promise<string> {
|
|
return new Promise((resolve, _reject) => {
|
|
return resolve(uuidv4());
|
|
});
|
|
}
|
|
|
|
/**
|
|
* Deletes an entity
|
|
*
|
|
* @param entityId - The entity ID to delete
|
|
*
|
|
* @return The deleted entity otherwise an error
|
|
*/
|
|
async deleteEntity(entityId: string): Promise<any> {
|
|
return entityId;
|
|
}
|
|
|
|
/**
|
|
* Update an entity value
|
|
*
|
|
* @param value - The updated update
|
|
*
|
|
* @returns The updated value otherwise it should throw an error
|
|
*/
|
|
async updateValue(value: NlpValue): Promise<NlpValue> {
|
|
return value;
|
|
}
|
|
|
|
/**
|
|
* Adds an entity value
|
|
*
|
|
* @param value - The value to add
|
|
*
|
|
* @returns The added value otherwise it should throw an error
|
|
*/
|
|
addValue(_value: NlpValueDocument): Promise<string> {
|
|
return new Promise((resolve, _reject) => {
|
|
return resolve(uuidv4());
|
|
});
|
|
}
|
|
|
|
/**
|
|
* Delete an entity value
|
|
*
|
|
* @param value - The value to delete
|
|
*
|
|
* @returns The deleted value otherwise an error
|
|
*/
|
|
async deleteValue(value: NlpValueFull): Promise<NlpValueFull> {
|
|
return value;
|
|
}
|
|
|
|
/**
|
|
* Returns training dataset in NLP provider compatible format
|
|
*
|
|
* @param samples - Sample to train
|
|
* @param entities - All available entities
|
|
*
|
|
* @returns The formatted NLP training set
|
|
*/
|
|
abstract format(samples: NlpSampleFull[], entities: NlpEntityFull[]): unknown;
|
|
|
|
/**
|
|
* Perform training request
|
|
*
|
|
* @param samples - Samples to train
|
|
* @param entities - All available entities
|
|
*
|
|
* @returns Training result
|
|
*/
|
|
abstract train(
|
|
samples: NlpSampleFull[],
|
|
entities: NlpEntityFull[],
|
|
): Promise<any>;
|
|
|
|
/**
|
|
* Perform evaluation request
|
|
*
|
|
* @param samples - Samples to evaluate
|
|
* @param entities - All available entities
|
|
*
|
|
* @returns NLP evaluation result
|
|
*/
|
|
abstract evaluate(
|
|
samples: NlpSampleFull[],
|
|
entities: NlpEntityFull[],
|
|
): Promise<any>;
|
|
|
|
/**
|
|
* Delete/Forget a sample
|
|
*
|
|
* @param sample - The sample to delete/forget
|
|
*
|
|
* @returns The deleted sample otherwise an error
|
|
*/
|
|
async forget(sample: NlpSample): Promise<NlpSample> {
|
|
return sample;
|
|
}
|
|
|
|
/**
|
|
* Returns only the entities that have strong confidence (> than the threshold), can return an empty result
|
|
*
|
|
* @param nlp - The nlp provider parse returned result
|
|
* @param threshold - Whenever to apply threshold filter or not
|
|
*
|
|
* @returns NLP Parsed entities
|
|
*/
|
|
abstract bestGuess(nlp: any, threshold: boolean): Nlp.ParseEntities;
|
|
|
|
/**
|
|
* Returns only the entities that have strong confidence (> than the threshold), can return an empty result
|
|
*
|
|
* @param text - The text to parse
|
|
* @param threshold - Whenever to apply threshold filter or not
|
|
* @param project - Whenever to request a specific model
|
|
*
|
|
* @returns NLP Parsed entities
|
|
*/
|
|
abstract parse(
|
|
text: string,
|
|
threshold?: boolean,
|
|
project?: string,
|
|
): Promise<Nlp.ParseEntities>;
|
|
}
|