Design Hub's functionality can be extended by plugins in several workflows to meet the expectations for different user groups and use-cases. Plugins are generally implemented as NodeJS modules implementing a simple stateless API, connecting to one or more web services or databases.
Table of contents:
Realtime plugins
Realtime plugins encapsulate functionality that describe 1 virtual compound in 1 specific area of phys-chem properties, ADMET, commercial availability, literature data, in-silico assay data, structure checks or modeling.
For more information specifically related to realtime plugins, check the Developer guide - real time plugins.
Resolver plugins
A resolver plugin converts a corporate identifier into a chemical structure using a structure database lookup.
For more information specifically related to resolver plugins, check the Developer guide - resolver plugins.
Storage plugins
A storage plugin establishes and maintains a flat database of all virtual compounds in Design Hub. Typically implemented with a SQL database connection, this can be used to support advanced analysis, visualizations, or a backup.
For more information specifically related to storage plugins, check the Developer guide - storage plugins.
Registry plugins
A registry plugin helps lookup the synthesis status and substance ID of a compound by periodically executing searches in a compound registration system or ELN.
For more information specifically related to registry plugins, check the Developer guide - registry plugins.
Import plugins
Import plugins load chemical structures into Design Hub based on user input or automatically, followed by deduplication and processing of records.
For more information specifically related to import plugins, check the Developer guide - import plugins.
Company plugins
A company plugin assists authorizing a user by fetching project and group membership for the user.
For more information specifically related to registry plugins, check the Developer guide - company plugins.
All plugins are loaded by the automatically during start up of the application. The definition of plugins to load are set in the configuration guide. For more, check the Configuration guide's servicesDirectory section.
For the successful development of a plugin, we recommend the following preparation:
{info} We recommend checking these basic introduction materials to get familiar with NodeJS NodeJS beginner guide, Youtube (78m), Getting started with NodeJS, Youtube (19m), Intro to NodeJS, Youtube (48m) NodeJS module description: https://nodejs.org/api/modules.html Promise introduction: https://web.dev/articles/promises?hl=en
Most Design Hub plugins benefit from a library of commonly used functions. Chemaxon is providing one as an npm package called @chemaxon/dh-utils, including the following functions:
@chemaxon/dh-utilsThis utility library is published as a scoped npm package. The @chemaxon scope can be accessed by obtaining a Chemaxon account and setting up an npm registry for the scope to Chemaxon's public package repository. The full list of steps to configure this npm registry is:
.npmrc file in your user home, or in the current working folderThe resulting file should look like the following:
@chemaxon:registry=https://chemaxon.jfrog.io/artifactory/api/npm/npm/
//chemaxon.jfrog.io/artifactory/api/npm/npm/:_authToken=<credentials here>
//chemaxon.jfrog.io/artifactory/api/npm/npm/:email=<email address here>
//chemaxon.jfrog.io/artifactory/api/npm/npm/:always-auth=trueOnce completed you can run:
npm install @chemaxon/dh-utils{info} The address of the repository changed from hub.chemaxon.com to chemaxon.jfrog.io in 2025 March.
const dhutils = require("@chemaxon/dh-utils");
async function calculate(body) {
  const smiles = await dhutils.convert(body.compounds[0].mrvSource, "smiles");
}async get(data): String | Buffer | Object
Sends an HTTP GET request using the NodeJS fetch API. For parameters see below at async req.
Returns (a Promise of) the response body depending on encoding specified in the request.
async post(data): String | Buffer | Object
Sends an HTTP POST request using the NodeJS fetch API. For parameters see below at async req.
Returns (a Promise of) the response body depending on encoding specified in the request.
async req(data): String | Buffer | Object
Sends an HTTP request using the NodeJS fetch API. Parameters:
| Name | Type | Required | Description | 
|---|---|---|---|
| url | URLorstring | yes | the HTTP URL to make the request to | 
| jar | CookieJar | no | See tough-cookie | 
| formData | FormData | no | See FormData Web API docs | 
| isMultipartFormData | boolean | no | Some APIs require passing multipart/form-dataheader even if binary data is not present | 
| json | boolean | no | Shorthand property to sending the body as stringified text with application/jsonheaders and parsing the response as JSON as well | 
| method | string | no | GET(default),POST,PUT,PATCH,DELETE | 
| headers | Object | no | Key-value pair of request headers | 
| body | any | no | Body/payload of the request | 
| followRedirect | boolean | no | Follow redirects | 
| timeout | number | no | Number of milliseconds after which the request is aborted and an error is thrown | 
| qs | Object | no | Key-value pair of URL encoded query strings (search params) to append to the path of the URL. See URLSearchParams | 
| auth | Object | no | Allows Basic authentication using Base64 encoded credentials when usernameandpasswordis specified. Allows sending Bearer tokens whenbeareris specified | 
| auth.username | string | no | Username of basic authentication for base64 encoding | 
| auth.password | string | no | Password of basic authentication for base64 encoding | 
| auth.bearer | string | no | Value of bearer token | 
Returns (a Promise of) the response body depending on encoding specified in the request.
async convert(structure, toFormat): String
Converts the input chemical structure to the specified format using JChem Microservices IO.
Parameters:
structure (string): the chemical structure to converttoFormat (string): the desired format string. See File Formats.Note: use of this method requires configuring the following environment variable:
JMS_IO_URL: URL of JChem Microservices IO, e.g.: http://localhost:8070/jwsio/Returns:
async convertFile(fileContents, toFormat): Buffer
Converts the input chemical structure file to the specified format using JChem Microservices IO.
Parameters:
fileContents (Buffer | String): the chemical structure file to converttoFormat (string): the desired format string. See File Formats.Note: use of this method requires configuring the following environment variable:
JMS_IO_URL: URL of JChem Microservices IO, e.g.: http://localhost:8070/jwsio/Returns:
async batchConvert(structures, toFormat): string[]
Converts the input chemical structure to the specified format using JChem Microservices IO.
Parameters:
structures (string[]): an array of chemical structure to converttoFormat (string): the desired format string. See File Formats.Note: use of this method requires configuring the following environment variable:
JMS_IO_URL: URL of JChem Microservices IO, e.g.: http://localhost:8070/jwsio/Returns:
async append(structures, toFormat): string[]
Merges multiple input chemical structure into a single one in the specified format using JChem Microservices IO.
Parameters:
structures (string[]): an array of chemical structurestoFormat (string): the desired format string. See File Formats.Note: use of this method requires configuring the following environment variable:
JMS_IO_URL: URL of JChem Microservices IO, e.g.: http://localhost:8070/jwsio/Returns:
async clean(structure, dimension, format): string
Rearranges of the atomic coordinates of the input structure.
Parameters:
structure (string): the chemical structure to processdimension (number): dimension to clean to. Values: 2, 3. Optional. Default: 2. format (string): the desired format string. See File Formats. Optional. Default: mrv.Note: use of this method requires configuring the following environment variable:
JMS_STRUCTURE_MANIPULATION_URL: URL of JChem Microservices Structure Manipulation, e.g.: http://localhost:8070/structure-manipulation/Returns:
async getImageURLs(structures, width?, height?): string[]
Generates data URLs with base64 encoded PNG images of the input chemical structures using the following format configuration: w${width},h${height},transbg,cpk,wireframe,nosource,marginSize2,maxscale28. See File Formats for specifications. 
Parameters:
structures (string[]): an array of chemical structure to render as imageswidth (number): width of the image. Optional. Default: 400.height (number): height of the image. Optional. Default: 260.Note: use of this method requires configuring the following environment variable:
JMS_IO_URL: URL of JChem Microservices IO, e.g.: http://localhost:8070/jwsio/Returns:
async getCleanedImageURLs(structures, width = 400, height = 200): string[]
Rearranges the atomic coordinates of the input chemical structures, and then generates data URLs with base64 encoded PNG images using the following format configuration: w${width},h${height},transbg,cpk,wireframe,nosource,marginSize2,maxscale28. See File Formats for specifications. 
Parameters:
structures (string[]): an array of chemical structure to render as imageswidth (number): width of the image. Optional. Default: 400.height (number): height of the image. Optional. Default: 260.Note: use of this method requires configuring the following environment variable:
JMS_IO_URL: URL of JChem Microservices IO, e.g.: http://localhost:8070/jwsio/JMS_STRUCTURE_MANIPULATION_URL: URL of JChem Microservices Structure Manipulation, e.g.: http://localhost:8070/structure-manipulation/Returns:
async PDBUtilities.load(pdbCode): string
Downloads a PDB file with the specified 4 letter code from the Protein Data Bank.
Parameters:
pdbCode (string): the 4 letter code of a PDB fileReturns:
async PDBUtilities.findLigands(pdbCode): string[]
Downloads a PDB file with the specified 4 letter code from the Protein Data Bank and extracts the list of available ligands.
Parameters:
pdbCode (string): the 4 letter code of a PDB fileReturns:
async PDBUtilities.getResidue(pdbCode, ligandCode): string
Downloads a PDB file with the specified 4 letter code from the Protein Data Bank and extracts a specific ligand.
Parameters:
pdbCode (string): the 4 letter code of a PDB fileligandCode (string): code of the ligand to extract, e.g.: HEM, A:HEM, or A:HEM350Returns:
async PDBUtilities.findLigandsFromFile(pdbFile): string[]
Extracts the list of available ligands from the specified PDB file.
Parameters:
pdbFile (string): the contents of the PDB fileReturns:
async PDBUtilities.getResidueFromFile(pdbFile, residueCode): string[]
Extracts a specific ligand from the specified PDB file.
Parameters:
pdbFile (string): the contents of the PDB fileligandCode (string): code of the ligand to extract, e.g.: HEM, A:HEM, or A:HEM350Returns:
v4.2.18
request dependency is replaced with node-fetchv3.1.0
append methodv3.0.1
ml-utils to dh-utilsv2.5.0
convertFile methodv2.4.0
PDBUtilities.findLigandsFromFile methodv2.2.2
batchConvert methodv2.1.6
clean methodv2.0.0
To find all available version numbers, use:
npm view @chemaxon/dh-utils versions