IHTSDO/component-identifier-service

View on GitHub
controllers/SctidBulk.js

Summary

Maintainability
D
2 days
Test Coverage
/**
 * Created by alo on 7/13/15.
 */
'use strict';

var security = require("./../blogic/Security");
var idDM=require("./../blogic/SCTIdBulkDataManager");
var bulkDM=require("./../blogic/BulkJobDataManager");
var job=require("../model/JobType");
var namespace = require("./../blogic/NamespaceDataManager");
var sctIdHelper = require("./../utils/SctIdHelper");
var schemeDM = require("./../blogic/SchemeDataManager");

function isAbleUser(namespaceId, user, callback){
    var able = false;
    security.admins.forEach(function(admin){
        if (admin == user)
            able = true;
    });
    if (!able){
        if (namespaceId != "false"){
            namespace.getPermissions(namespaceId, function(err, permissions) {
                if (err)
                    return next(err.message);
                else{
                    var possibleGroups = [];
                    permissions.forEach(function(permission){
                        if (permission.role == "group"){
                            possibleGroups.push(permission.username);
                        }else if (permission.username == user)
                            able = true;
                    });
                    if (!able) {
                        security.getGroups(user,function(err, result) {
                            if (err) {
                                console.log("Error accessing groups", err);
                                callback(able);
                            } else {
                                result.forEach(function(loopGroup){
                                    if (loopGroup == "namespace-" + namespaceId)
                                        able = true;
                                    else if (possibleGroups.indexOf(loopGroup) != -1)
                                        able = true;
                                });
                                callback(able);
                            }
                        });
                    } else {
                        callback(able);
                    }
                }
            });
        }else
            callback(able);
    }else
        callback(able);
}

function isSchemeAbleUser(schemeName, user, callback){
    var able = false;
    security.admins.forEach(function(admin){
        if (admin == user)
            able = true;
    });
    if (!able){
        if (schemeName != "false"){
            schemeDM.getPermissions(schemeName, function(err, permissions) {
                if (err)
                    return next(err.message);
                else{
                    var possibleGroups = [];
                    permissions.forEach(function(permission){
                        if (permission.role == "group"){
                            possibleGroups.push(permission.username);
                        }else if (permission.username == user)
                            able = true;
                    });
                    if (!able && possibleGroups.length) {
                        security.getGroups(user,function(err, result) {
                            if (err) {
                                console.log("Error accessing groups", err);
                                callback(able);
                            } else {
                                result.forEach(function(loopGroup){
                                    if (possibleGroups.indexOf(loopGroup) != -1)
                                        able = true;
                                });
                                callback(able);
                            }
                        });
                    } else {
                        callback(able);
                    }
                }
            });
        }else
            callback(able);
    }else
        callback(able);
}


module.exports.getSctids = function getSctids (req, res, next) {
    var token = req.swagger.params.token.value;
    var sctids = req.swagger.params.sctids.value;
    var sctidsArray = sctids.replace(/ /g,"").split(",");
    security.authenticate(token, function(err, data) {
        if (err) {
            return next({message: err.message, statusCode: 401});
        }
        idDM.getSctids(sctidsArray,function(err,records){
            if (err){
                return next(err.message);
            }
            res.setHeader('Content-Type', 'application/json');
            res.end(JSON.stringify(records));
        });
    });
};

module.exports.getSctidsBody = function getSctids (req, res, next) {
    var token = req.swagger.params.token.value;
    var sctids = req.swagger.params.sctids.value.sctids;
    var sctidsArray = sctids.replace(/ /g,"").split(",");
    security.authenticate(token, function(err, data) {
        if (err) {
            return next({message: err.message, statusCode: 401});
        }
        idDM.getSctids(sctidsArray,function(err,records){
            if (err){
                return next(err.message);
            }
            res.setHeader('Content-Type', 'application/json');
            res.end(JSON.stringify(records));
        });
    });
};

module.exports.getSctidBySystemIds = function getSctidBySystemIds (req, res, next) {
    var token = req.swagger.params.token.value;
    var systemIds = req.swagger.params.systemIds.value;
    var namespaceId = req.swagger.params.namespaceId.value;
    var systemIdsArray = systemIds.replace(/ /g,"").split(",");
    security.authenticate(token, function(err, data) {
        if (err) {
            return next({message: err.message, statusCode: 401});
        }
        idDM.getSctidBySystemIds(namespaceId,systemIdsArray,function(err,records){
            if (err){
                return next(err.message);
            }
            res.setHeader('Content-Type', 'application/json');
            res.end(JSON.stringify(records));
        });
    });
};

module.exports.generateSctids = function generateSctids (req, res, next) {
    var token = req.swagger.params.token.value;
    var generationData = req.swagger.params.generationData.value;

    security.authenticate(token, function(err, data) {
        if (err) {
            return next({message: err.message, statusCode: 401});
        }
        isAbleUser(generationData.namespace, data.user.name, function(able){
            if (able){
                if ((generationData.namespace==0 && generationData.partitionId.substr(0,1)!="0")
                    || (generationData.namespace!=0 && generationData.partitionId.substr(0,1)!="1")){
                    return next("Namespace and partitionId parameters are not consistent.");
                }
                if (generationData.systemIds && generationData.systemIds.length!=0 && generationData.systemIds.length!=generationData.quantity){
                    return next("SystemIds quantity is not equal to quantity requirement");
                }
                generationData.author=data.user.name;
                generationData.model=job.MODELS.SctId;

                if ((!generationData.systemIds || generationData.systemIds.length==0)
                    && (generationData.generateLegacyIds && generationData.generateLegacyIds.toUpperCase()=="TRUE" &&
                        generationData.partitionId.substr(1,1)=="0")) {
                    var arrayUuids=[];
                    for (var i=0;i<generationData.quantity;i++){
                        arrayUuids.push(guid());
                    }
                    generationData.systemIds=arrayUuids;
                    generationData.autoSysId=true;
                }
                var additionalJobs=[];


                bulkDM.saveJob(generationData,job.JOBTYPE.generateSctids,function(err,sctIdBulkJobRecord){
                    if (err) {

                        return next(err.message);
                    }
                    if (generationData.generateLegacyIds && generationData.generateLegacyIds.toUpperCase()=="TRUE" &&
                        generationData.partitionId.substr(1,1)=="0") {

                        var generationMetadata=JSON.parse(JSON.stringify(generationData));
                        delete generationMetadata.namespace;
                        delete generationMetadata.partitionId;
                        generationMetadata.model=job.MODELS.SchemeId;
                        isSchemeAbleUser("SNOMEDID", data.user.name, function(able){
                            if (able){
                                generationMetadata.scheme = 'SNOMEDID';
                                bulkDM.saveJob(generationMetadata, job.JOBTYPE.generateSchemeIds, function (err, snoIdBulkJobRecord) {
                                    if (err) {

                                        return next(err.message);
                                    }

                                    additionalJobs.push(snoIdBulkJobRecord);
                                    isSchemeAbleUser("CTV3ID", data.user.name, function(able){
                                        if (able){
                                            var generationCTV3IDMetadata = JSON.parse(JSON.stringify(generationMetadata));
                                            generationCTV3IDMetadata.scheme = 'CTV3ID';
                                            bulkDM.saveJob(generationCTV3IDMetadata, job.JOBTYPE.generateSchemeIds, function (err, ctv3IdBulkJobRecord) {
                                                if (err) {

                                                    return next(err.message);
                                                }
                                                additionalJobs.push(ctv3IdBulkJobRecord);
                                                sctIdBulkJobRecord.additionalJobs = additionalJobs;
                                                res.setHeader('Content-Type', 'application/json');
                                                res.end(JSON.stringify(sctIdBulkJobRecord));
                                            });
                                        }else{
                                            sctIdBulkJobRecord.additionalJobs = additionalJobs;
                                            res.setHeader('Content-Type', 'application/json');
                                            res.end(JSON.stringify(sctIdBulkJobRecord));
                                        }
                                    });
                                });
                            }else{
                                isSchemeAbleUser("CTV3ID", data.user.name, function(able){
                                    if (able){
                                        var generationCTV3IDMetadata=JSON.parse(JSON.stringify(generationMetadata));
                                        generationCTV3IDMetadata.scheme = 'CTV3ID';
                                        bulkDM.saveJob(generationCTV3IDMetadata, job.JOBTYPE.generateSchemeIds, function (err, ctv3IdBulkJobRecord) {
                                            if (err) {

                                                return next(err.message);
                                            }
                                            additionalJobs.push(ctv3IdBulkJobRecord);
                                            sctIdBulkJobRecord.additionalJobs=additionalJobs;
                                            res.setHeader('Content-Type', 'application/json');
                                            res.end(JSON.stringify(sctIdBulkJobRecord));
                                        });
                                    }else{
                                        res.setHeader('Content-Type', 'application/json');
                                        res.end(JSON.stringify(sctIdBulkJobRecord));
                                    }
                                });
                            }
                        });
                    }else {
                        res.setHeader('Content-Type', 'application/json');
                        res.end(JSON.stringify(sctIdBulkJobRecord));
                    }
                });
            }else
                return next("No permission for the selected operation");
        });
    });
};


module.exports.registerSctids = function registerSctids (req, res, next) {
    var token = req.swagger.params.token.value;
    var registrationData = req.swagger.params.registrationData.value;
    security.authenticate(token, function(err, data) {
        if (err) {
            return next({message: err.message, statusCode: 401});
        }

        isAbleUser(registrationData.namespace, data.user.name, function(able){
            if (able){
                if (!registrationData.records || registrationData.records.length==0){

                    return next("Records property cannot be empty.");
                }
                var namespace;
                var error=false;
                registrationData.records.forEach(function(record){
                    if (error) return;
                    namespace = sctIdHelper.getNamespace(record.sctid);
                    if (namespace!=registrationData.namespace){
                        error=true;
                        return next("Namespaces differences between schemeid: " + record.sctid + " and parameter: " + registrationData.namespace);
                    }
                });
                if (error) return;
                registrationData.author=data.user.name;
                registrationData.model=job.MODELS.SctId;
                bulkDM.saveJob(registrationData,job.JOBTYPE.registerSctids,function(err,bulkJobRecord){
                    if (err) {

                        return next(err.message);
                    }

                    res.setHeader('Content-Type', 'application/json');
                    res.end(JSON.stringify(bulkJobRecord));
                });
            }else
                return next("No permission for the selected operation");
        });
    });
};

module.exports.reserveSctids = function reserveSctids (req, res, next) {
    var token = req.swagger.params.token.value;
    var reservationData = req.swagger.params.reservationData.value;
    security.authenticate(token, function(err, data) {
        if (err) {
            return next({message: err.message, statusCode: 401});
        }
        isAbleUser(reservationData.namespace, data.user.name, function(able){
            if (able){
                if ((reservationData.namespace==0 && reservationData.partitionId.substr(0,1)!="0")
                    || (reservationData.namespace!=0 && reservationData.partitionId.substr(0,1)!="1")){
                    return next("Namespace and partitionId parameters are not consistent.");
                }
                if (!reservationData.quantity || reservationData.quantity<1){

                    return next("Quantity property cannot be lower to 1.");
                }
                reservationData.author=data.user.name;
                reservationData.model=job.MODELS.SctId;
                bulkDM.saveJob(reservationData,job.JOBTYPE.reserveSctids,function(err,bulkJobRecord){
                    if (err) {

                        return next(err.message);
                    }

                    res.setHeader('Content-Type', 'application/json');
                    res.end(JSON.stringify(bulkJobRecord));
                });
            }else
                return next("No permission for the selected operation");
        });
    });
};

module.exports.deprecateSctids = function deprecateSctids (req, res, next) {
    var token = req.swagger.params.token.value;
    var deprecationData = req.swagger.params.deprecationData.value;
    security.authenticate(token, function(err, data) {
        if (err) {
            return next({message: err.message, statusCode: 401});
        }
        isAbleUser(deprecationData.namespace, data.user.name, function(able){
            if (able){
                if (!deprecationData.sctids || deprecationData.sctids.length<1){

                    return next("Sctids property cannot be empty.");
                }

                var namespace;
                var error=false;
                deprecationData.sctids.forEach(function(sctid){
                    if (error) return;
                    namespace = sctIdHelper.getNamespace(sctid);
                    if (namespace!=deprecationData.namespace){
                        error=true;
                        return next("Namespaces differences between schemeid: " + sctid + " and parameter: " + deprecationData.namespace);
                    }
                });
                if (error) return;
                deprecationData.author=data.user.name;
                deprecationData.model=job.MODELS.SctId;
                bulkDM.saveJob(deprecationData,job.JOBTYPE.deprecateSctids,function(err,bulkJobRecord){
                    if (err) {

                        return next(err.message);
                    }

                    res.setHeader('Content-Type', 'application/json');
                    res.end(JSON.stringify(bulkJobRecord));
                });
            }else
                return next("No permission for the selected operation");
        });
    });
};

module.exports.releaseSctids = function releaseSctids (req, res, next) {
    var token = req.swagger.params.token.value;
    var releaseData = req.swagger.params.releaseData.value;
    security.authenticate(token, function(err, data) {
        if (err) {
            return next({message: err.message, statusCode: 401});
        }
        isAbleUser(releaseData.namespace, data.user.name, function(able){
            if (able){
                if (!releaseData.sctids || releaseData.sctids.length<1){

                    return next("Sctids property cannot be empty.");
                }

                var namespace;
                var error=false;
                releaseData.sctids.forEach(function(sctid){
                    if (error) return;
                    namespace = sctIdHelper.getNamespace(sctid);
                    if (namespace!=releaseData.namespace){
                        error=true;
                        return next("Namespaces differences between schemeid: " + sctid + " and parameter: " + releaseData.namespace);
                    }
                });
                if (error) return;
                releaseData.author=data.user.name;
                releaseData.model=job.MODELS.SctId;
                bulkDM.saveJob(releaseData,job.JOBTYPE.releaseSctids,function(err,bulkJobRecord){
                    if (err) {

                        return next(err.message);
                    }

                    res.setHeader('Content-Type', 'application/json');
                    res.end(JSON.stringify(bulkJobRecord));
                });
            }else
                return next("No permission for the selected operation");
        });
    });
};

module.exports.publishSctids = function publishSctids (req, res, next) {
    var token = req.swagger.params.token.value;
    var publicationData = req.swagger.params.publicationData.value;
    security.authenticate(token, function(err, data) {
        if (err) {
            return next({message: err.message, statusCode: 401});
        }
        isAbleUser(publicationData.namespace, data.user.name, function(able){
            if (able){
                if (!publicationData.sctids || publicationData.sctids.length<1){

                    return next("Sctids property cannot be empty.");
                }

                var namespace;
                var error=false;
                publicationData.sctids.forEach(function(sctid){
                    if (error) return;
                    namespace = sctIdHelper.getNamespace(sctid);
                    if (namespace!=publicationData.namespace){
                        error=true;
                        return next("Namespaces differences between schemeid: " + sctid + " and parameter: " + publicationData.namespace);
                    }
                });
                if (error) return;
                publicationData.author=data.user.name;
                publicationData.model=job.MODELS.SctId;
                bulkDM.saveJob(publicationData,job.JOBTYPE.publishSctids,function(err,bulkJobRecord){
                    if (err) {

                        return next(err.message);
                    }

                    res.setHeader('Content-Type', 'application/json');
                    res.end(JSON.stringify(bulkJobRecord));
                });
            }else
                return next("No permission for the selected operation");
        });
    });
};

var guid = (function() {
    function s4() {
        return Math.floor((1 + Math.random()) * 0x10000)
            .toString(16)
            .substring(1);
    }
    return function() {
        return s4() + s4() + '-' + s4() + '-' + s4() + '-' +
            s4() + '-' + s4() + s4() + s4();
    };
})();