/node-sms-terminal

SMS Terminal

Primary LanguageJavaScriptMIT LicenseMIT

Node SMS Terminal

Introduction

Node SMS Terminal is designed to handle GSM communication such as sending or receiving short message (SMS), querying USSD data from network provider. It utilizes modem dongle usually used to connect to data network from provider, so it doesn't need special or expensive hardware.

Node SMS Terminal doesn't provide direct method to handle its functionality, but it uses socket communication to provide those functionality to other party.

Currently, there is Node SMS Gateway other party implementation for this terminal.

Installation

Stand alone installation is available using GIT.

$ cd ~
$ git clone https://github.com/tohenk/node-sms-terminal.git
$ cd node-sms-terminal
$ npm install

A web interface installation is needed as its now a separate package.

$ npm install @ntlab/sms-terminal-ui

To run application (On some Linux distribution replace node with nodejs)

$ node app.js --auto

Configuration

Node SMS Terminal uses JSON configuration named config.json in the working directory, but it can be told to use configuration elsewhere.

database

Set Sequelize database connection parameter.

{
    "database": {
        "dialect":"mysql",
        "host": "localhost",
        "username":"username",
        "password":"password",
        "database":"smsgw",
        "timezone":"Asia/Jakarta"
    }
}

secret

Set socket connection secret. Each socket client must send auth with secret and will be checked against this value. If it matches, connection accepted, otherwise connection will be closed.

{
    "secret": "CHANGEME"
}

security

Set web interface username and password. Default username and password is both admin. To secure your instance, it is advised to change default password.

{
    "security": {
        "username": "admin",
        "password": "admin"
    }
}

Command line options

$ node app.js --help
Usage:
  node app.js [options]

Options:
--config=config-file  Read app configuration from file
--driver=driver-file  Read driver from file
--port=port, -p=port  Set web server port to listen
--logdir=directory    Set the log file location
--auto, -a            Automatically open all available ports
--read-new-message    Once the terminal opened, try to read new messages
--log-ussd, -u        Add ussd command to activity

Web interface

Node SMS Terminal web interface can be accessed via port 8000 (default) or as specified by the command line options above.

Todo

  • Text SMS mode currently not supported
  • STK functionality still missing
  • Socket and web interface currently doesn't support https