mirror of
				https://github.com/immich-app/immich.git
				synced 2025-11-04 03:27:09 -05:00 
			
		
		
		
	* refactor microservices to machine-learning * Update tGithub issue template with correct task syntax * Added microservices container * Communicate between service based on queue system * added dependency * Fixed problem with having to import BullQueue into the individual service * Added todo * refactor server into monorepo with microservices * refactor database and entity to library * added simple migration * Move migrations and database config to library * Migration works in library * Cosmetic change in logging message * added user dto * Fixed issue with testing not able to find the shared library * Clean up library mapping path * Added webp generator to microservices * Update Github Action build latest * Fixed issue NPM cannot install due to conflict witl Bull Queue * format project with prettier * Modified docker-compose file * Add GH Action for Staging build: * Fixed GH action job name * Modified GH Action to only build & push latest when pushing to main * Added Test 2e2 Github Action * Added Test 2e2 Github Action * Implemented microservice to extract exif * Added cronjob to scan and generate webp thumbnail at midnight * Refactor to ireduce hit time to database when running microservices * Added error handling to asset services that handle read file from disk * Added video transcoding queue to process one video at a time * Fixed loading spinner on web while loading covering the info panel * Add mechanism to show new release announcement to web and mobile app (#209) * Added changelog page * Fixed issues based on PR comments * Fixed issue with video transcoding run on the server * Change entry point content for backward combatibility when starting up server * Added announcement box * Added error handling to failed silently when the app version checking is not able to make the request to GITHUB * Added new version announcement overlay * Update message * Added messages * Added logic to check and show announcement * Add method to handle saving new version * Added button to dimiss the acknowledge message * Up version for deployment to the app store
		
			
				
	
	
		
			40 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			40 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
import { Injectable, Logger } from '@nestjs/common';
 | 
						|
import * as cocoSsd from '@tensorflow-models/coco-ssd';
 | 
						|
import * as tf from '@tensorflow/tfjs-node';
 | 
						|
import * as fs from 'fs';
 | 
						|
 | 
						|
@Injectable()
 | 
						|
export class ObjectDetectionService {
 | 
						|
  private cocoSsdModel: cocoSsd.ObjectDetection;
 | 
						|
 | 
						|
  constructor() {
 | 
						|
    Logger.log(
 | 
						|
      `Running Node TensorFlow Version : ${tf.version['tfjs']}`,
 | 
						|
      'ObjectDetection',
 | 
						|
    );
 | 
						|
    cocoSsd.load().then((model) => (this.cocoSsdModel = model));
 | 
						|
  }
 | 
						|
  async detectObject(thumbnailPath: string) {
 | 
						|
    try {
 | 
						|
      const isExist = fs.existsSync(thumbnailPath);
 | 
						|
      if (isExist) {
 | 
						|
        const tags = new Set();
 | 
						|
        const image = fs.readFileSync(thumbnailPath);
 | 
						|
        const decodedImage = tf.node.decodeImage(image, 3) as tf.Tensor3D;
 | 
						|
        const predictions = await this.cocoSsdModel.detect(decodedImage);
 | 
						|
 | 
						|
        for (const result of predictions) {
 | 
						|
          if (result.score > 0.5) {
 | 
						|
            tags.add(result.class);
 | 
						|
          }
 | 
						|
        }
 | 
						|
 | 
						|
        tf.dispose(decodedImage);
 | 
						|
        return [...tags];
 | 
						|
      }
 | 
						|
    } catch (e) {
 | 
						|
      console.log('Error reading file ', e);
 | 
						|
    }
 | 
						|
  }
 | 
						|
}
 |