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 🙏

© 2025 – Pkg Stats / Ryan Hefner

ewd-qoper8-vistarpc

v2.8.0

Published

VistA RPC Interface for use with ewd-qoper8 and Express

Downloads

19

Readme

ewd-qoper8-vistarpc: Plug-in ewd-qoper8 module to enable REST access to VistA RPCs

Rob Tweed [email protected]
24 February 2016, M/Gateway Developments Ltd http://www.mgateway.com

Twitter: @rtweed

Google Group for discussions, support, advice etc: http://groups.google.co.uk/group/enterprise-web-developer-community

ewd-qoper8-vistarpc

This plug-in module for ewd-qoper8 and Express provides the worker module support to access VistA RPCs

VistA is the Open Source Electronic Healthcare Record used by the US Dept of Veterans Affairs.

For details on ewd-qoper8, see: http://gradvs1.mgateway.com/download/ewd-qoper8.pdf

Installing

   npm install ewd-qoper8-vistarpc
   

Using ewd-qoper8-vistarpc

A working example is provided in the /example directory.

The master process is defined in /example/ewd-vista-express

The worker process module is /example/vista-worker-module

Preparation

Currently the example is designed for use with VistA running on an InterSystems' Cache database platform.

You'll need to install the following:

   npm install express
   npm install body-parser
   npm install ewd-qoper8
   npm install ewd-qoper8-express
   npm install ewd-qoper8-cache     (this automatically installs the ewd-document-store module)
   npm install ewd-session
   npm install ewd-qoper8-vistarpc       

The worker module (/example/vista-worker-module.js) assumes that the VistA database is in a Cache namespace called 'VISTA', and that Cache is installed in /opt/cache.

To adapt the module for use with your system, edit the params object within these lines in the worker module:

  var connectCacheTo = require('ewd-qoper8-cache');
  var params = {
    namespace: 'VISTA'
  };
  connectCacheTo(this, params);

You can specify any or all of the following properties of params:

  • path: The path of your Cache system's MGR directory (/opt/cache/mgr)
  • username: The username for connecting to Cache (_SYSTEM)
  • password: This password for connecting to Cache (SYS)
  • namespace: The Cache namespace to connect to (USER)

You need to also make sure that you install two Cache routines into the namespace you'll be connecting to:

  • ewdSymbolTable.m which you'll find in the ewd-session module directory in the path /mumps. Save and compile this with the routine name ewdSymbolTable
  • ewdVistARPC.m which you'll find in the ewd-qoper8-vistarpc module directory in the path /mumps. Save and compile this with the routine name ewdVistARPC

If you're using Cache, you can use the XML export version of each of these routines, eg from within the namespace where you want the routines to reside you can import, save and compile the routines programmatically as follows:

  w $system.OBJ.Load("/home/rob/ewd/node_modules/ewd-session/mumps/ewdSymbolTable.xml","ck")
  w $system.OBJ.Load("/home/rob/ewd/node_modules/ewd-qoper8-vistarpc/mumps/ewdVistARPC.xml","ck")

  ;Note: modify the file paths appropriately for your configuration

By default, the master process (/example/ewd-vista-express.js) will start Express and tell it to listen on port 8080. If you want to use a different port, edit this line in the master process file:

    app.listen(8080);

By default, ewd-qoper8 will use a worker pool-size of 1. If you want it to make more workers available to ewd-qoper8, simply add the following lines after the app.listen line:

    q.on('start', function() {
      this.setWorkerPoolSize(3);
    });

Start Express and ewd-qoper8

Make sure you're in the directory you were in when you installed all the Node.js modules

   node node_modules/ewd-qoper8-vistarpc/example/ewd-vista-express

You may need to do this as sudo, depending on the permissions settings for Express and Cache.

You should see the following:

  Worker Bootstrap Module file written to node_modules/ewd-qoper8-worker.js
  ========================================================
  ewd-qoper8 is up and running.  Max worker pool size: 1
  ========================================================
  ewd-qoper8-vistarpc is now running

Express will now be running and listening on port 8080 (or whatever you may have changed it to)

Using ewd-qoper8-vistarpc

Use a REST Client (eg Chrome Advanced REST Client)

The first thing you need to do is login to VistA. You'll need to know a valid VistA Access and Verify code:

   POST http://192.168.1.100:8080/vista/login

The data payload should be a JSON document containing the Access and Verify codes, eg:

  {
    "accessCode": "mYAccessC0de!",
    "verifyCode": "mYver1fYC0de#"
  }

Make sure you set the Content-Type to application/json

If the credentials aren't correct you'll get an HTTP error response back. Otherwise you should see a VistA welcome/login object returned, along with a session token eg:

  {
    "token": "82aae3b1-3aa4-49de-8cbf-e794e47744ca"
    "displayName": "CHERYL"
    "greeting": "Good afternoon CHERYL"
    "lastSignon": " You last signed on today at 12:39"
    "messages": [5]
    0: " You last signed on today at 12:39"
    1: "You have 311 new messages. (311 in the 'IN' basket)"
    2: ""
    3: "Enter '^NML' to read your new messages."
    4: "You've got PRIORITY mail!" -
  }

Copy and paste the value of the token property (without the quotes) into the REST Client's Authorization Header field.

You can now run any RPC that the logged in user has access rights to use:

   POST http://192.168.1.100:8080/vista/runRPC/[RPC Name]

eg

   POST http://192.168.1.100:8080/vista/runRPC/DDR GETS ENTRY DATA

Note: you may need to URL escape the spaces within the RPC name with %23

The payload should be a JSON object that defines the RPC arguments, eg:

  [
    {
      "type": "LIST",
      "value": {
        "FILE": "200",
        "FIELDS": ".01",
        "IENS": ".5,",
        "FLAGS": "IE"
      }
    }
  ]

For the above example, if successful you should see a response such as:

  {
    "type": "ARRAY"
    "value": {
      1: "[Data]"
      2: "200^.5^.01^POSTMASTER^POSTMASTER"
    } -
  }

Make sure all requests have the Authorization header set to the token returned by the original /initiate request, and that their Content-Type is application/json

License

Copyright (c) 2016 M/Gateway Developments Ltd,
Reigate, Surrey UK.
All rights reserved.

http://www.mgateway.com
Email: [email protected]

Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at

  http://www.apache.org/licenses/LICENSE-2.0                           
                                                                       

Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and
limitations under the License.