Media-server
This commit is contained in:
@@ -13,7 +13,8 @@
|
|||||||
"bookshop": "cds watch packages/bookshop",
|
"bookshop": "cds watch packages/bookshop",
|
||||||
"bookstore": "cds watch packages/bookstore",
|
"bookstore": "cds watch packages/bookstore",
|
||||||
"products-service": "cds watch packages/products-service",
|
"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": {
|
"dependencies": {
|
||||||
"@sap/cds": "latest",
|
"@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",
|
"license": "SAP SAMPLE CODE LICENSE",
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@sap/cds": "latest",
|
"@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