Sign Up for Free

RunKit +

Try any Node.js package right in your browser

This is a playground to test code. It runs a full Node.js environment and already has all of npm’s 400,000 packages pre-installed, including codemash with all npm packages installed. Try it out:

var codemash = require("codemash")

This service is provided by RunKit and is not affiliated with npm, Inc or the package authors.

codemash v1.2.20

CodeMash tools for Node and javascript developers. Access tools from npm


CodeMash for javascript developers. All the documentation can be found here


Use the package manager codemash to install codemash.

npm install codemash


import { config } from 'codemash';

      secretKey: '<YOUR_SECRET_KEY>',
      projectId: '<YOUR_PROJECT_ID>'
    }, process.env.NODE_ENV)

See full documentation here

Database Module

Get Data:

import { db } from 'codemash';

// gets all first 100 employees 
export async function getEmployees() {
    return await db.getRecords('emplpyees', 0, 100);

// gets all first 100 active employees
// get only first name and last name - projection
// sort out by created on date in DESC order. 
export async function getActiveEmployees() {    

    const filter = JSON.stringify({ 'is_active': true });
    const response = 
        await db.getRecords('employees', 0, 100,
        { first_name: 1, last_name: 1 }, 
        { created_on: -1 });  
    return response;

Pagination (by default page size is set to 10):

await db.getRecords('employees', 0, 100);


await db.getRecords('employees', 0, 100, { created_on: -1 });


const filter = JSON.stringify({ 'is_active': true });
await db.getRecords('employees', 0, 100, { created_on: -1 }, filter);

See full documentation here

Get One Record:

import { db } from 'codemash';

// gets employee by id
export async function getEmployeeDetails(id) {
    const response = await db.getRecord('employees', id);
    return response;

// gets employee by custom filter
export async function getEmployeeByUserId(id) {    
    const filter = { userId : id };    
    return await db.getRecordWithFilter(collectionName, filter, null);

See full documentation here

TODO Projection:

Save Data:

import { db } from 'codemash';

const request = {
    start: '1588855312059', // Unix time stamp in miliseconds
    end: '1588855340191', // Unix time stamp in miliseconds
    employee: 'some_user_id',
    type: 'paid',

export async function saveHolidaysRequest(request) {
    const response = await db.saveRecord('holidays', request);
    return response;

See full documentation here

Replace Data:

import { db } from 'codemash';

export async function replaceEmployeeInformation(id, employee) {
    return await db.replaceRecord('employees', { _id: id }, employee);

Update Data:

import { db } from 'codemash';

export async function activateEmployee(id) {

    return await db.updateRecord('employees', 
        { _id: id }, 
        { $set: { 'is_active' : 1 }});

See full documentation here

Delete Data:

import { db } from 'codemash';

export async function deleteEmployee(id) {
    return await db.deleteRecord('employees', { _id: id });

See full documentation here

Get Taxonomy terms:

import { db } from 'codemash';

export async function getCountries() {
    return await db.getTaxonomyTerms('countries');

export async function getCities() {
    return await db.getTaxonomyTerms('cities');

Documentation about Terms module you can find here

TODO Files Module

Documentation about Files moduke you can find here


Documentation about Membership module you can find here

Users Authentication

TODO Notifications Module

Documentation about Notifications you can find here

Emails Push


RunKit is a free, in-browser JavaScript dev environment for prototyping Node.js code, with every npm package installed. Sign up to share your code.
Sign Up for Free