Media-server

This commit is contained in:
Lakshmi C Rajeev
2019-11-29 12:30:07 +05:30
parent c2d0fba1d8
commit 7137bf227e
6 changed files with 108 additions and 17 deletions

View File

@@ -13,7 +13,8 @@
"bookshop": "cds watch packages/bookshop",
"bookstore": "cds watch packages/bookstore",
"products-service": "cds watch packages/products-service",
"reviews-service": "cds watch packages/reviews-service"
"reviews-service": "cds watch packages/reviews-service",
"media-server": "cds watch packages/media-server"
},
"dependencies": {
"@sap/cds": "latest",

View File

@@ -0,0 +1,13 @@
namespace sap.capire.media;
entity Media {
key id:Integer;
@Core.MediaType: mediaType
content : LargeBinary ;
@Core.IsMediaType: true
mediaType : String;
fileName : String;
applicationName:String;
}

View File

@@ -1,15 +0,0 @@
namespace sap.capire.media;
service MediaServer {
entity Images {
key url : URL;
type : String enum { jpeg; png; gif; };
content : Image;
}
}
type ImageURL : URL;
// type ImageURL : Association to MediaServer.Images;
//> would need Assotiations targeting off service to turn into references w/ foreign keys
type Image : LargeBinary @stream;
type URL : String(222);

View File

@@ -6,6 +6,7 @@
"license": "SAP SAMPLE CODE LICENSE",
"dependencies": {
"@sap/cds": "latest",
"express": "*"
"express": "*",
"lokijs": "^1.5.6"
}
}

View File

@@ -0,0 +1,8 @@
using { sap.capire.media as db } from '../db/data-model';
namespace sap.capire.media;
service MediaServer {
entity Media as projection on db.Media ;
}

View File

@@ -0,0 +1,83 @@
module.exports = (srv) => {
var loki = require('lokijs');
var db = new loki('DB');
var mediaDB= db.addCollection("Media");
var Readable = require('stream').Readable;
var PassThroughStream = require('stream').PassThrough;
srv.before('CREATE', 'Media', (req) => {
var obj = mediaDB.insert({media: ""});
req.data.id=obj.$loki;
})
srv.on ('UPDATE', 'Media', async (req,next) => {
try{
var url = req._.req.path;
if (url.indexOf("content")>0) {
const id = req.data.id;
var obj = mediaDB.get(id);
if(obj==null) {
req.reject(404,"No record found for the ID");
return;
}
var stream = new PassThroughStream();
let chunks = [];
stream.on('data', (chunk) => {
chunks.push(chunk);
});
stream.on('end', () =>{
obj.media = Buffer.concat(chunks).toString('base64');
mediaDB.update(obj);
});
req.data.content.pipe(stream);
} else return next()
}catch(error){
req.reject(404,"Media DB error")
console.log(error)
return
}
})
srv.on("READ","Media", (req,next)=>{
try{
var url = req._.req.path;
if (url.indexOf("content")>0) {
const id = req.data.id;
if(mediaDB.get(id)==null) {
req.reject(404,"Media not found for the ID");
return ;
}
var decodedMedia = new Buffer( mediaDB.get(id).media.split(';base64,').pop(), 'base64');
return _formatResult(decodedMedia);
}
else return next() //> delegate to next/default handlers
}catch(error){
req.reject(404,"Media DB error")
return
}
})
srv.on("DELETE","Media", (req,next)=>{
try{
const id = req.data.id;
var obj=mediaDB.get(id);
if(obj!=null) {
mediaDB.remove(obj)
}
return next() //> delegate to next/default handlers
}catch(error){
req.reject(404,"Media DB error ")
}
})
function _formatResult (decodedMedia) {
var readable= new Readable
var result = new Array()
readable.push(decodedMedia)
readable.push(null)
result.push({value:readable})
return result
}
}