Socket
Book a DemoInstallSign in
Socket

anuvadak

Package Overview
Dependencies
Maintainers
1
Versions
6
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install
Package was removed
Sorry, it seems this package was removed from the registry

anuvadak

Add basic serialization and body barsing methods to Muneem framework

2.1.3
unpublished
latest
Source
npmnpm
Version published
Weekly downloads
0
Maintainers
1
Weekly downloads
 
Created
Source

anuvadak (अनुवादक)

Add necessary serialization and body parsing methods to Muneem framework.

How to use

const muneem = require('muneem')();
const anuvadak = require('anuvadak');
muneem.use(anuvadak.plainText);
muneem.use(anuvadak.xml, xmlOptions);

muneem.add('handler', function(asked, answer){
    answer.writeText( data );
})

plainText

alias: text

it allows you to response with plain text.

const muneem = require('muneem')();
const anuvadak = require('anuvadak');
//muneem.use(anuvadak.plainText);
muneem.use(anuvadak.text);

function requestHandler(asked, answer){
    answer.writeText("This is text data");
}

writeText(data[, type[, length[, safe[, append] ] ] ] );

safe : if true and answer.data is already present then new data will not be set. append : if true and safe is false then new data will be appended to old data.

buffer

it allows you to response with buffer data.

const muneem = require('muneem')();
const anuvadak = require('anuvadak');
muneem.use(anuvadak.buffer);

function requestHandler(asked, answer){
    answer.writeBuffer( Buffer.from("This text data will be converted to buffer.") );
}

writeBuffer(data[, type[, length[, safe[, append] ] ] ] )

safe : if true and answer.data is already present then new data will not be set. append : if true and safe is false then new data will be appended to old data.

stream

it allows you to response with streams.

const muneem = require('muneem')();
const anuvadak = require('anuvadak');
muneem.use(anuvadak.stream);

function requestHandler(asked, answer){
    const fileReadableStream = fs.createReadStream( filePath );
    answer.writeStream( fileReadableStream );
}

writeStream(data[, type[, length[, safe[, append] ] ] ] )

safe : if true and answer.data is already present then new data will not be set. append : if true and safe is false then new data will be pipe to old data.

json

it allows you to read js object from request body. it also allows you to response with js objects which gets converted to JSON.

const muneem = require('muneem')();
const anuvadak = require('anuvadak');
muneem.use(anuvadak.json);

function requestHandler(asked, answer){
    //var requestObject = await asked.readJson();
    await asked.readJson();
    requestObject = asked.body;
    //..
    answer.writeJson( responseObject );
}

readJson() writeJson(data[, type[, length[, safe] ] ])

safe : if true and answer.data is already present then new data will not be set.

xml

it allows you to read XML data from request body as js object. it also allows you to response with js objects which gets converted to XML.

const muneem = require('muneem')();
const anuvadak = require('anuvadak');
//muneem.use(anuvadak.xml); //for default options
muneem.use(anuvadak.xml, { //global options
    read : xmlReadOptions, // https://github.com/NaturalIntelligence/fast-xml-parser#xml-to-json
    write : xmlWriteOptions // https://github.com/NaturalIntelligence/fast-xml-parser#json--js-object-to-xml
});

function requestHandler(asked, answer){
    //var requestObject = await asked.readXml();
    await asked.readXml();
    requestObject = asked.body;
    //..
    answer.writeXml( responseObject );
}

readXml()

writeXml(data[, type[, length[, safe] ] ])

safe : if true and answer.data is already present then new data will not be set.

we use fast-xml-parser to parse JS object to XML. If you want to overwrite options, you can set them either globally or at route level. Check above example to set global options.

Route level

muneem.route({
    to : serviceName,
    anuvadak: {
        write : {
            xml : {
                ignoreAttributes : true
            }
        }
    }
});

or from mapping file

- route:
    to: serviceName
    anuvadak:
        write:
            xml:
                ignoreAttributes : true

When global and route level both options are present then route level options are used for parsing.

URL encoded Forms

it allows you to read URL encoded form data from request URL as js object.

const muneem = require('muneem')();
const anuvadak = require('anuvadak');
//muneem.use(anuvadak.urlForm); //https://www.npmjs.com/package/qs
muneem.use(anuvadak.urlEncodedForm);

function requestHandler(asked, answer){
    //var requestObject =  asked.readUrlForm(options);
    asked.readUrlForm(options);
    var requestObject = asked.body;
    //..
}

Form

it allows you to read form data (including files) from request body.

const muneem = require('muneem')();
const anuvadak = require('anuvadak');
var globalOptions = {
    encoding : 'utf-8',
    file : {
        uploadTo : os.tmpdir(),  //temp upload.
        saveTo : "", // target folder
        keepExtensions : true,
        maxSize : 1024 * 1024, //1 MB
        hash : false,
        on : {
            name : (fileName) => {},//It'll emit to get fileName before moving to saveTo
            duplicate : (field, file, filePath) => {//It'll emit if saveTo is set but another file with same name exist.
            move : () => {}, //it'll not emit if saveTo is set and after the file has been moved or failed to move.
            receive : (name, file) => {}, //it'll not emit if saveTo is set.
            found : (name, file) => {}, //It'll emit when a file field is found in request
        }
    },
    field : {
        maxSize : 200 * 1024, // 200 KB
        maxCount : 20,
        on : {
            receive : () => {},
        },
    },
    on : {
        error : (err) => {},
        end : () => {},
        aborted : () => {}
    }
}
muneem.use(anuvadak.form, globalOptions); 

function requestHandler(asked, answer){
    var options = {
        saveTo : "profilePics" //Paths can be absolute or relative to the path given in global options
    }
    //var requestObject =  await asked.readForm(options);
    await asked.readForm(options);
    var requestObject = asked.body; //use as requestObject.fiekdName
    //..
}

Though you can read files, it's good to read it mixed forms or the forms with non-file fields only. To read the forms with files field only, use readFiles. If you want to handle the form yourself, you can get the instance of form handler which is ready with the configuration you've provided.

function requestHandler(asked, answer){
    var formHandler = asked.getFormHandle(options);

    formHandler.on("field", function(name, value) {
        //..
    });

    formHandler.on("file", function(name, file) {
        //..
    });

    formHandler.read();

    var requestObject = asked.body; //use as requestObject.fiekdName
    //..
}

This uses formidable underneath.

Read Files

it allows you to read only files from request stream.

const muneem = require('muneem')();
const anuvadak = require('anuvadak');
var globalOptions = {
    encoding : 'utf-8',
    sync : false,
    uploadTo : os.tmpdir(),  //temp upload.
    saveTo : "", // target folder
    keepExtensions : true,
    maxSize : 1024 * 1024, //1 MB
    hash : false,
    on : {
        name : (fileName) => {},//It'll emit to get fileName before moving to saveTo
        duplicate : (field, file, filePath) => {//It'll emit if saveTo is set but another file with same name exist.
        move : () => {}, //it'll not emit if saveTo is set and after the file has been moved or failed to move.
        receive : (name, file) => {}, //it'll not emit if saveTo is set.
        found : (name, file) => {}, //It'll emit when a file field is found in request
        error : (err) => {},
        end : () => {},
        aborted : () => {}
    }
}
muneem.use(anuvadak.readFiles, globalOptions); 

function fileRequestHandlerSync(asked, answer){
    var options = {
        saveTo : "profilePics" //Paths can be absolute or relative to the path given in global options
    }
    //var requestObject =  await asked.readForm(options);
    await asked.readFiles({
        sync : true
    });
    var requestObject = asked.body; //use as requestObject.fieldName
    //..
}

function fileRequestHandler(asked, answer){
    var options = {
        saveTo : "profilePics" //Paths can be absolute or relative to the path given in global options
    }
    asked.readFiles(options);
    //..
}

Though you can read files, it's good to read it mixed forms or the forms with non-file fields only. To read the forms with files field only, use readFiles

This uses formidable underneath.

Send Files

it allows you to send static files to the client.

const muneem = require('muneem')();
const anuvadak = require('anuvadak');

muneem.use(anuvadak.sendFiles, {
    root : path.join(__dirname ),  //required 
    ignore404 : true,                   // ignore default "resource not found" handling
    ignoreRequestPath : true      // force to ignore URL path
});

muneem.addHandler("main", async (asked,answer) => {
    //answer.sendFile("static/index.html"); // path.join( root , "static/index.html" );
    answer.sendFile(); // path.join( root , asked.path );
} ) ;

muneem.route({
    uri : "/"
    to : "main"
})

muneem.route({
    uri : "/static/*"
    to : "main"
})

You can set ignore404 to ignore by default handling of file not found case. Otherwise it invokes routeNotFound handler that can be set as muneem.setRouteNotFound(fn).

You can set ignoreRequestPath to not to read file path from the URL. In this case, you must pass the file path, relative to the root path, when you call sendFile(filePath).

You can visit send npm package for more options and events.

Keywords

muneem

FAQs

Package last updated on 30 Nov 2018

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

About

Packages

Stay in touch

Get open source security insights delivered straight into your inbox.

  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc

U.S. Patent No. 12,346,443 & 12,314,394. Other pending.