tango-app-api-infra 3.0.25-dev → 3.0.27-dev

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/app.js ADDED
@@ -0,0 +1,41 @@
1
+
2
+ import express from 'express';
3
+ import { infraRouter, internalInfraRouter, userInfraRouter, storeInfraRouter, clientInfraRouter } from './index.js';
4
+ import dotenv from 'dotenv';
5
+ import responseMiddleware from './config/response/response.js';
6
+ import errorMiddleware from './config/response/error.js';
7
+ import { connectdb } from './config/database/database.js';
8
+ import pkg from 'body-parser';
9
+ import cors from 'cors';
10
+ const { json, urlencoded } = pkg;
11
+ import fileUpload from 'express-fileupload';
12
+ const env=dotenv.config();
13
+ const app = express();
14
+ const PORT = process.env.PORT || 3000;
15
+ app.use( fileUpload() );
16
+
17
+ if ( env.error ) {
18
+ logger.error( '.env not found' );
19
+ process.exit( 1 );
20
+ }
21
+ app.use( json( { limit: '500mb' } ) );
22
+ app.use(
23
+ urlencoded( {
24
+ extended: true,
25
+ } ),
26
+ );
27
+ app.use( cors() );
28
+ app.use( responseMiddleware );
29
+ app.use( errorMiddleware );
30
+ app.use( '/infra', infraRouter );
31
+ app.use( '/internalInfra', internalInfraRouter );
32
+ app.use( '/userInfra', userInfraRouter );
33
+ app.use( '/storeInfra', storeInfraRouter );
34
+ app.use( '/clientInfra', clientInfraRouter );
35
+
36
+
37
+ app.listen( PORT, () => {
38
+ console.log( `server is running on port= ${PORT} ` );
39
+ connectdb();
40
+ } );
41
+
package/package.json CHANGED
@@ -1,11 +1,11 @@
1
1
  {
2
2
  "name": "tango-app-api-infra",
3
- "version": "3.0.25-dev",
3
+ "version": "3.0.27-dev",
4
4
  "description": "infra",
5
- "main": "index.js",
5
+ "main": "app.js",
6
6
  "type": "module",
7
7
  "scripts": {
8
- "start": "nodemon --exec \"eslint --fix . && node index.js\""
8
+ "start": "nodemon --exec \"eslint --fix . && node app.js\""
9
9
  },
10
10
  "engines": {
11
11
  "node": ">=18.10.0"
@@ -4,6 +4,7 @@ import { aggregateTangoTicket } from '../services/tangoTicket.service.js';
4
4
  import { findOneStore } from '../services/store.service.js';
5
5
  import dayjs from 'dayjs';
6
6
  import { findinfraReason } from '../services/infraReason.service.js';
7
+ import { signedUrl } from 'tango-app-api-middleware';
7
8
  export async function storeTicketList( req, res ) {
8
9
  try {
9
10
  let date = await getUTC( new Date( req.body.fromDate ), new Date( req.body.toDate ) );
@@ -775,3 +776,52 @@ export async function viewedgeAppLog( req, res ) {
775
776
  return res.sendError( error, 500 );
776
777
  }
777
778
  }
779
+
780
+ export async function cameraAngleChange( req, res ) {
781
+ try {
782
+ const angleChange = await getOpenSearchData( 'camera-angle-change',
783
+ {
784
+ 'size': 1,
785
+ 'query': {
786
+ 'bool': {
787
+ 'must': [
788
+ {
789
+ 'term': {
790
+ 'date.keyword': dayjs( req.body.Date ).format( 'DD-MM-YYYY' ),
791
+ },
792
+ },
793
+ {
794
+ 'term': {
795
+ 'store_id.keyword': req.body.storeId,
796
+ },
797
+ },
798
+ ],
799
+ },
800
+ },
801
+ } );
802
+ let result = angleChange.body.hits.hits.length > 0 ? angleChange.body.hits.hits[0]._source : [];
803
+ if ( result && result.cameraAngleChangeStatus && result.camera_info.length > 0 ) {
804
+ let changeDetected = result.camera_info.filter( ( cam ) => cam.stream == req.body.StreamName );
805
+ if ( changeDetected.length == 1 ) {
806
+ let params = {
807
+ Bucket: 'tango-client-sandbox',
808
+ file_path: changeDetected[0].path,
809
+ };
810
+ let Image = await signedUrl( params );
811
+ res.sendSuccess( {
812
+ StreamName: req.body.StreamName,
813
+ angleChangeImage: Image,
814
+ anglechange: true,
815
+ resolution: changeDetected[0].resolution,
816
+ } );
817
+ } else {
818
+ res.sendError( 'no data', 204 );
819
+ }
820
+ } else {
821
+ res.sendError( 'no data', 204 );
822
+ }
823
+ } catch ( error ) {
824
+ logger.error( { error: error, function: 'cameraAngleChange' } );
825
+ return res.sendError( error, 500 );
826
+ }
827
+ }
@@ -1,7 +1,7 @@
1
1
 
2
2
  import express from 'express';
3
3
  import { isAllowedSessionHandler, authorize } from 'tango-app-api-middleware';
4
- import { storeTicketList, storeTicketcard, edgeAppLogTable, viewedgeAppLog } from '../controllers/storeInfra.controlller.js';
4
+ import { storeTicketList, storeTicketcard, edgeAppLogTable, viewedgeAppLog, cameraAngleChange } from '../controllers/storeInfra.controlller.js';
5
5
  export const storeInfraRouter = express.Router();
6
6
 
7
7
  storeInfraRouter.post( '/storeTicketList', isAllowedSessionHandler, authorize( {
@@ -20,5 +20,8 @@ storeInfraRouter.post( '/viewedgeAppLog', isAllowedSessionHandler, authorize( {
20
20
  userType: [ 'client', 'tango' ], access: [
21
21
  { featureName: 'manage', name: 'tickets', permissions: [ 'isView' ] } ],
22
22
  } ), viewedgeAppLog );
23
-
23
+ storeInfraRouter.post( '/cameraAngleChange', isAllowedSessionHandler, authorize( {
24
+ userType: [ 'client', 'tango' ], access: [
25
+ { featureName: 'manage', name: 'tickets', permissions: [ 'isView' ] } ],
26
+ } ), cameraAngleChange );
24
27
 
@@ -26,8 +26,9 @@ userInfraRouter.post( '/workHistory', isAllowedSessionHandler, authorize( {
26
26
  { featureName: 'manage', name: 'tickets', permissions: [ 'isView' ] } ],
27
27
  } ), workHistory );
28
28
  userInfraRouter.post( '/storeInfraList', isAllowedSessionHandler, authorize( {
29
- userType: [ 'tango' ], access: [
30
- { featureName: 'manage', name: 'tickets', permissions: [ 'isView' ] } ],
29
+ userType: [ 'tango', 'client' ], access: [
30
+ { featureName: 'manage', name: 'tickets', permissions: [ 'isView' ] },
31
+ ],
31
32
  } ), storeInfraList );
32
33
 
33
34