Media-server
This commit is contained in:
@@ -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",
|
||||
|
||||
13
packages/media-server/db/data-model.cds
Normal file
13
packages/media-server/db/data-model.cds
Normal 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;
|
||||
}
|
||||
@@ -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);
|
||||
@@ -6,6 +6,7 @@
|
||||
"license": "SAP SAMPLE CODE LICENSE",
|
||||
"dependencies": {
|
||||
"@sap/cds": "latest",
|
||||
"express": "*"
|
||||
"express": "*",
|
||||
"lokijs": "^1.5.6"
|
||||
}
|
||||
}
|
||||
|
||||
8
packages/media-server/srv/media-service.cds
Normal file
8
packages/media-server/srv/media-service.cds
Normal 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 ;
|
||||
}
|
||||
|
||||
|
||||
83
packages/media-server/srv/media-service.js
Normal file
83
packages/media-server/srv/media-service.js
Normal 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
|
||||
}
|
||||
|
||||
}
|
||||
Reference in New Issue
Block a user