# Parakeetx

This is a fork of the original repo found [here](https://github.com/ahmadnassri/parakeet) which adds the ability to host an HTTPS version of parakeet

[![License][license-image]][license-url] [![version][npm-image]][npm-url] [![Build Status][circle-image]][circle-url]

> Echo server for TCP/UDP/HTTP

![screenshot](screenshot.png)

Watch the screencast [here](https://asciinema.org/a/37456)

## About

> The common parakeet (Melopsittacus undulatus), is a popular talking-bird species because of their potential for large vocabularies, ease of care and well-socialized demeanor.
> [https://en.wikipedia.org/wiki/Parakeet](https://en.wikipedia.org/wiki/Parakeet)

![parakeet](parakeet.png)

## Message Format

| event                        | format                                                   | example                                                  |
| ---------------------------- | -------------------------------------------------------- | -------------------------------------------------------- |
| server start                 | `[TIME] ▶️ TYPE LISTEN_IP LISTEN_PORT`                   | `[03:32:54 AM] ▶️ TCP 127.0.0.1 1338`                    |
| connection open              | `[TIME] ⚪ REMOTE_IP REMOTE_PORT`                         | `[03:32:54 AM] ⚪️ TCP 127.0.1.1 1338`                    |
| connection close             | `[TIME] ⚫️️ REMOTE_IP REMOTE_PORT`                       | `[03:32:54 AM] ⚫️️️ TCP 127.0.1.1 1338`                  |
| data recieved                | `[TIME] ✔ REMOTE_IP REMOTE_PORT [BYTES] "MESSAGE"`       | `[03:33:00 AM] ✔ (127.0.0.1 57619) [8] "hello!\r\n"`     |
| http signature _(http only)_ | `[TIME] ✔ REMOTE_IP REMOTE_PORT HTTP_VERSION METHOD URL` | `[03:32:33 AM] ✔ (127.0.0.1 49575) HTTP/1.1 POST /`      |
| http headers _(http only)_   | `[TIME] ✔ REMOTE_IP REMOTE_PORT KEY: VALUE`              | `[03:32:33 AM] ✔ (127.0.0.1 49575) Host: localhost:8080` |

## Sample Output

###### TCP

```plain
[03:32:54 AM] ▶️ TCP 127.0.0.1 1338
[03:32:57 AM] ⚪ (127.0.0.1 57619)
[03:33:00 AM] ✔ (127.0.0.1 57619) [8] "hello!\r\n"
[03:33:08 AM] ⚫️️️ (127.0.0.1 57619)
```

###### UDP

```plain
[03:32:41 AM] ▶️ UDP4 127.0.0.1 1337
[03:32:45 AM] ✔ (127.0.0.1 45464) [6] "hello\n"
[03:32:46 AM] ✔ (127.0.0.1 45464) [6] "world\n"
```

###### HTTP

```plain
[03:32:27 AM] ▶️ HTTP 127.0.0.1 8080
[03:32:31 AM] ⚪ (127.0.0.1 49574)
[03:32:31 AM] ✔ (127.0.0.1 49574) HTTP/1.1 POST /
[03:32:31 AM] ✔ (127.0.0.1 49574) Host: localhost:8080 Content-Length: 36 Content-Type: application/json; charset=utf-8 Accept-Encoding: gzip, deflate, compress Accept: application/json User-Agent: HTTPie/0.8.0
[03:32:31 AM] ✔ (127.0.0.1 49574) [36] {"name": "ahmad", "city": "toronto"}
[03:32:31 AM] ⚫️️️ (127.0.0.1 49574)

[03:32:33 AM] ⚪ (127.0.0.1 49575)
[03:32:33 AM] ✔ (127.0.0.1 49575) HTTP/1.1 POST /
[03:32:33 AM] ✔ (127.0.0.1 49575) Host: localhost:8080 Content-Length: 23 Content-Type: application/x-www-form-urlencoded; charset=utf-8 Accept-Encoding: gzip, deflate, compress Accept: */* User-Agent: HTTPie/0.8.0
[03:32:33 AM] ✔ (127.0.0.1 49575) [23] name=ahmad&city=toronto
[03:32:33 AM] ⚫️️️ (127.0.0.1 49575)
```

## Install

```bash
npm install parakeetx
```

## Usage

```plain

  Usage: parakeetx [options] [command]


  Commands:

    http   start HTTP echo server
    https  start HTTPs echo server
    tcp    start TCP echo server
    udp    start UDP echo server

  Options:

    -h, --help                        output usage information
    -V, --version                     output the version number
    -p, --port <number>               port to listen on
    -a, --address <address>           network address to listen on
    -k, --key <key>                   SSL private key file path (for use with https)
    -c, --certificate <certificate>   SSL certificate file path (for use with https)
```

---
> Author: [Ahmad Nassri](https://www.ahmadnassri.com/) &bull; 
> Github: [@ahmadnassri](https://github.com/ahmadnassri) &bull; 
> Twitter: [@AhmadNassri](https://twitter.com/AhmadNassri)

[license-url]: LICENSE
[license-image]: https://img.shields.io/github/license/ahmadnassri/parakeet.svg?style=for-the-badge&logo=circleci

[circle-url]: https://circleci.com/gh/ahmadnassri/workflows/parakeet
[circle-image]: https://img.shields.io/circleci/project/github/ahmadnassri/parakeet/master.svg?style=for-the-badge&logo=circleci

[npm-url]: https://www.npmjs.com/package/parakeet
[npm-image]: https://img.shields.io/npm/v/parakeet.svg?style=for-the-badge&logo=npm
