mirror of
				https://github.com/labring/FastGPT.git
				synced 2025-10-20 18:54:09 +00:00 
			
		
		
		
	 d857a391b3
			
		
	
	d857a391b3
	
	
	
		
			
			* fix: rerank auth token * feat: check null value * bind notify * perf: reasoning config * Adapt mongo 4.x index
		
			
				
	
	
		
			83 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			83 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| import { addLog } from '../../common/system/log';
 | |
| import mongoose, { Model } from 'mongoose';
 | |
| 
 | |
| export default mongoose;
 | |
| export * from 'mongoose';
 | |
| 
 | |
| export const connectionMongo = (() => {
 | |
|   if (!global.mongodb) {
 | |
|     global.mongodb = mongoose;
 | |
|   }
 | |
| 
 | |
|   return global.mongodb;
 | |
| })();
 | |
| 
 | |
| const addCommonMiddleware = (schema: mongoose.Schema) => {
 | |
|   const operations = [
 | |
|     /^find/,
 | |
|     'save',
 | |
|     'create',
 | |
|     /^update/,
 | |
|     /^delete/,
 | |
|     'aggregate',
 | |
|     'count',
 | |
|     'countDocuments',
 | |
|     'estimatedDocumentCount',
 | |
|     'distinct',
 | |
|     'insertMany'
 | |
|   ];
 | |
| 
 | |
|   operations.forEach((op: any) => {
 | |
|     schema.pre(op, function (this: any, next) {
 | |
|       this._startTime = Date.now();
 | |
|       this._query = this.getQuery ? this.getQuery() : null;
 | |
| 
 | |
|       next();
 | |
|     });
 | |
| 
 | |
|     schema.post(op, function (this: any, result: any, next) {
 | |
|       if (this._startTime) {
 | |
|         const duration = Date.now() - this._startTime;
 | |
| 
 | |
|         const warnLogData = {
 | |
|           query: this._query,
 | |
|           op,
 | |
|           duration
 | |
|         };
 | |
| 
 | |
|         if (duration > 1000) {
 | |
|           addLog.warn(`Slow operation ${duration}ms`, warnLogData);
 | |
|         }
 | |
|       }
 | |
|       next();
 | |
|     });
 | |
|   });
 | |
| 
 | |
|   return schema;
 | |
| };
 | |
| 
 | |
| export const getMongoModel = <T>(name: string, schema: mongoose.Schema) => {
 | |
|   if (connectionMongo.models[name]) return connectionMongo.models[name] as Model<T>;
 | |
|   console.log('Load model======', name);
 | |
|   addCommonMiddleware(schema);
 | |
| 
 | |
|   const model = connectionMongo.model<T>(name, schema);
 | |
| 
 | |
|   // Sync index
 | |
|   syncMongoIndex(model);
 | |
| 
 | |
|   return model;
 | |
| };
 | |
| 
 | |
| const syncMongoIndex = async (model: Model<any>) => {
 | |
|   if (process.env.SYNC_INDEX !== '0' && process.env.NODE_ENV !== 'test') {
 | |
|     try {
 | |
|       model.syncIndexes({ background: true });
 | |
|     } catch (error) {
 | |
|       addLog.error('Create index error', error);
 | |
|     }
 | |
|   }
 | |
| };
 | |
| 
 | |
| export const ReadPreference = connectionMongo.mongo.ReadPreference;
 |