npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

oracle-json

v5.0.0

Published

call oracle stored procedures using json input and output params

Downloads

70

Readme

oracle-json

nodejs module to call oracle stored procedures using json input and output params. Automatically sends HTTP 503 response for stored procedure errors or when the database connection is lost. Exits when the database connection is lost ( assumes it will be restarted automatically by upstart or some such process) Requires the oracledb driver module.

Install

  npm install oracle-json

Options:

  • database - connection parameters for the ''oracle'' node module.
  • databasePool - database pool settings which can be:
    • poolTimeout - time (s) that unused connections will be closed. Default 30.
    • queueTimeout - time (ms) to wait for a connection before returning an Error. Default 120000.
    • poolMin - The smallest number of connections the pool will shrink to - Default 0.
    • poolMax - The greatest number of connections the pool will grow to - Default 1.

The following options are used on the call to execute a procedure; query

  • procedure the name of the stored procedure to execute. If not specified a `query``must be specified instead
  • query the query to execute. The response will be executed as a resultset and returned in res.locals.data. You can reference the 'inputs'or requestvalues by name e.gselect * from table where id = :idwhereinputs` is {'id': 12}
  • noRespond do not automatically respond to the client but save results of procedure as res.locals.data
  • request use the object named from express as the input to the procedure e.g. request:"query" will use req.query
  • inputs specifiy the input parameters explicitly in this object
  • debugMaskList array of object properties that should be masked in debug data e.g.    debugMaskList:["card.cardNumber","card.expDate"]
  • outputType
    • BLOB: response will by read without any modification.
    • CURSOR: output will be processed as 1 or more (see ) CURSORS and converted to Arrays of JSON (using field names are object property names)
    • CLOB (default): CLOB will be converted to JSON. Output will be set to res.locals.data
  • outputCount The number of output Cursors to expect. Default 1.
  • numRows number of rows to prefetch when processing queries/cursors.
  • databaseConnectionErrors an array of Oracle connection errors codes that will cause the current connection pool to be shutdown, a new one started and the requested query/proc to be reprocessed. e.g     databaseConnectionErrors:["ORA-04068","ORA-06508","ORA-04061","ORA-03135"].

Examples:

The examples below assume the express module is also being used.

Initialization

var oj=require('oracle-json')(options);
app.use(oj.connect());

Called a Stored Procedure which returns JSON

var priceCall={procedure:"pkg_test.getPrice",request:"body",output:true} ;
app.get('/price',oj.execute(priceCall));

Guarantee your connection is good

conntest() runs the simplest query, select 1 from dual and reconnects on error. The overhead for this test seems about 2ms.

var priceCall={procedure:"pkg_test.getPrice",request:"body",output:true} ;
app.get('/price',oj.conntest(),oj.execute(priceCall));
//execsafe includes conntest and execute
app.get('/pricesafe',oj.execsafe(priceCall));

Release History

|Version|Date|Description| |:--:|:--:|:--| |v5.0.0|2021-06-21|Upgrade dependency to oracledb v5. Updated node compatibility to match |v4.0.1|2020-01-27|Remove password from console logging of settings. |v4.0.0|2019-08-12|Upgrade to oracledb v4 |v3.1.0|2019-07-24|Upgrade module dependencies |v3.0.0|2018-02-19|Upgrade to version 3.0.x of oracledb and debug modules. |v2.1.6|2018-02-19|Use console.log when exiting process to ensure log messages are written. |v2.1.5|2018-01-29|Fix invalid reference in debug mesage. |v2.1.4|2017-05-29|Fixed retry of Pool Termination where hundreds or thousands of failed requests could be made - there was not waiting before retry. | |v2.1.3|2017-03-06|Added support to restart the connection pool on certain connection errors| |v2.1.2|2017-01-24|Fixed errors being raised because error handlign code was not returning from function| |v2.1.1|2016-10-19|Improved Error reporting| |v2.1.0|2016-10-04|Added handling of CURSORS and ResultSets from queries| |v2.0.2|2016-08-04|support the autoCommit property| |v2.0.1|2016-03-01|uses callback to handle errors| |v2.0.0|2016-03-01|Switched from oracle to oracledb module| |v1.0.4|2016-03-01|Publish BLOB handling missing from 1.0.3| |v1.0.3|2015-08-14|BLOB output type handled and oracle module updated to version 0.3.8| |v1.0.2|2015-07-21|Split input parameter | |v1.0.1|2014-09-22|Test executions | |v1.0.0|2014-09-15|Connection pooling | |v0.8.5|2014-09-10|Check for keep open | |v0.8.4|2014-09-10|Close when test fails | |v0.8.3|2014-09-10|Reconnect when test fails | |v0.8.2|2014-09-09|Test a connection with a simple query | |v0.8.1|2014-09-08|Close connection | |v0.8.0|2014-09-08|Error status| |v0.7.10|2014-09-08|Monitor reconnect times| |v0.7.9|2014-09-07|Monitor total procedure executions| |v0.7.8|2014-09-01|Connection maxRetries| |v0.7.7|2014-09-01|Debug logging| |v0.7.6|2014-08-24|Raise an error when not responding directly. Otherwise send json error| |v0.7.4|2014-08-22|Close on error status| |v0.7.3|2014-08-21|Check database status returned| |v0.7.2|2014-08-21|Parse JSON result| |v0.6.5|2014-07-03|Use any object in the express request as input to the procedure call| |v0.5.5|2014-07-03|Reverted to oracle0.3.4| |v0.5.1|2014-07-02|Check TNS settings not used| |v0.5.0|2014-07-02|Use oracle.connectSync| |v0.4.2|2014-06-18|Option to use req.params as input| |v0.4.1|2014-05-16|Configure whether to respond to the client| |v0.4.0|2014-05-13|Keep the connection open if configured| |v0.2.1|2013-12-18|Make one attempt to reconnect to Oracle per request| |v0.1.1|2013-12-05|Initial Version|

License

(The MIT License)

Copyright (c) 2016 PC

Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the 'Software'), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.