2016-06-28 18:53:10 +03:00
# Mongoose - Embedded Web Server / Embedded Networking Library
2012-08-25 22:48:14 +01:00
2020-12-05 11:46:12 +00:00
![License: GPLv2 ](https://img.shields.io/badge/license-GPL_2-green.svg "License" )
2020-12-18 11:32:59 +00:00
[![Build Status ]( https://github.com/cesanta/mongoose/workflows/build/badge.svg )](https://github.com/cesanta/mongoose/actions)
2020-12-07 08:08:21 +00:00
[![Code Coverage ](https://codecov.io/gh/cesanta/mongoose/branch/master/graph/badge.svg )](https://codecov.io/gh/cesanta/mongoose)
2021-01-05 18:10:01 +00:00
[![Fuzzing Status ](https://oss-fuzz-build-logs.storage.googleapis.com/badges/mongoose.svg )](https://bugs.chromium.org/p/oss-fuzz/issues/list?sort=-opened& can=1& q=proj:mongoose)
2014-04-09 18:10:49 +01:00
2020-12-06 21:12:05 +00:00
Mongoose is a networking library for C/C++. It implements event-driven
non-blocking APIs for TCP, UDP, HTTP, WebSocket, MQTT. It has been designed
for connecting devices and bringing them online. On the market since 2004, used
by vast number of open source and commercial products - it even runs on the
International Space Station! Mongoose makes embedded network programming fast,
robust, and easy.
2014-04-09 18:10:49 +01:00
2021-03-19 14:02:23 +00:00
Are you a company working on a connected product or software? We can offer you assistance to guarantee your integration success. [Book a free call with our experienced engineer for the initial integration development session. ](https://calendly.com/cesanta/mongoose-library-remote-control-for-connected-devices )
2021-03-10 13:42:46 +00:00
Source code and documentation:
2017-07-17 13:10:24 +01:00
- [Download Mongoose Source Code here ](https://www.cesanta.com/download.html )
2020-12-10 14:21:38 +00:00
- [Read Mongoose documentation ](https://cesanta.com/docs/ )
2015-08-20 08:56:14 +01:00
2020-12-05 11:41:23 +00:00
Connectivity is vital for software and embedded devices, but there are many
pitfalls to consider when embedding a web server. This white paper breaks down
on the top 9 things to avoid when embedding a web server.
2020-06-24 17:08:35 +01:00
- [Download “9 Things NOT to do when embedding a web server” white paper here ](https://www.cesanta.com/whitepaper.html )
2021-02-05 16:55:26 +00:00
# Looking for a pre-compiled Mongoose web server Windows or Mac binary?
2021-02-07 14:51:37 +00:00
- [Download pre-compiled Mongoose web server binary ](https://mongoose.ws/ )
2021-02-05 16:55:26 +00:00
2021-02-05 16:56:06 +00:00
# Looking for a complete IoT solution? Check out
2020-12-05 11:41:23 +00:00
- [VCON ](https://vcon.io ) - Arduino compatible MCU modules with built-in firmware OTA updates
2020-12-08 16:53:35 +00:00
- [Mongoose OS ](https://mongoose-os.com ) - open source embedded operating system for low-power connected microcontrollers. Secure, designed for commercial Internet of Things products
2016-10-18 18:35:47 +07:00
# Support
2020-12-10 14:21:38 +00:00
- [Study Mongoose examples ](https://github.com/cesanta/mongoose/tree/master/examples )
2020-12-05 11:41:23 +00:00
- [Support Forum - ask your technical questions here ](https://forum.cesanta.com/c/mongoose-library/6 )
2017-07-17 13:10:24 +01:00
- [Commercial licensing and support available ](https://www.cesanta.com/licensing.html )
2020-12-10 14:21:38 +00:00
- [Check out latest releases ](https://github.com/cesanta/mongoose/releases )
2013-01-01 23:05:09 +00:00
2015-09-08 13:49:03 +02:00
# Features
2021-02-04 10:40:33 +00:00
* Cross-platform: works on Linux/UNIX, MacOS, Windows, Android, FreeRTOS, etc
* Supported embedded architectures: ESP32, ESP8266, TI, NRF52, STM32, PIC32, NXP, and more
2020-12-29 17:59:05 +00:00
* Builtin protocols: plain TCP/UDP, HTTP, MQTT, Websocket
2021-02-04 10:40:33 +00:00
* SSL/TLS support: mbedTLS, OpenSSL or custom (via API)
2020-12-29 17:59:05 +00:00
* Asynchronous DNS resolver
2015-09-08 13:49:03 +02:00
* Tiny static and run-time footprint
* Source code is both ISO C and ISO C++ compliant
* Very easy to integrate: just copy
[mongoose.c ](https://raw.githubusercontent.com/cesanta/mongoose/master/mongoose.c ) and
[mongoose.h ](https://raw.githubusercontent.com/cesanta/mongoose/master/mongoose.h )
files to your build tree
2016-03-04 16:08:19 +01:00
# Licensing
2016-10-19 15:33:08 +01:00
Mongoose is released under Commercial and [GNU GPL v.2 ](http://www.gnu.org/licenses/old-licenses/gpl-2.0.html ) open source licenses.
2016-03-04 16:08:19 +01:00
2017-07-17 13:10:24 +01:00
Commercial Projects: [Contact us for commercial license. ](https://www.cesanta.com/contact.html )
2015-09-08 13:49:03 +02:00
2015-08-18 09:50:00 +01:00
# Dashboard Example
2014-03-11 16:59:17 +00:00
2015-09-21 17:16:16 +03:00
Mongoose is often used to implement device dashboards and real-time
data exchange over Websocket. Here is a dashboard example that illustrates
the functionality:
2017-07-17 13:10:24 +01:00
![](http://www.cesanta.com/images/dashboard.png)
2014-03-11 16:59:17 +00:00
2017-07-17 13:10:24 +01:00
[Developing a new product? Contact us today to discuss how Mongoose can help. ](https://www.cesanta.com/contact.html )
2014-03-11 16:59:17 +00:00
2016-03-01 10:41:24 +00:00
# Contributions
2020-02-13 10:20:05 +00:00
Contributions are welcome! Please follow the guidelines below:
- Sign [Cesanta CLA ](https://cesanta.com/cla.html ) and send GitHub pull request
- When making pull requests, please make sure that it has only one commit,
and imlements/fixes only one piece of functionality
2016-03-01 10:41:24 +00:00
2021-02-05 16:55:26 +00:00