mongoose/README.md

113 lines
6.2 KiB
Markdown
Raw Normal View History

# 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-10 13:42:46 +00:00
Source code and documentation:
- [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
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)
# Why Mongoose?
Mongoose provides a high level of assurance in terms of reliability and security:
- Reliable and tested with time: over 16 years of track record.
- Proven track record: deployed to tens of millions devices in production environments worldwide.
- Trusted by hundreds of companies big and small: Bosch, Siemens, Samsung, HP, Dell, Google, Intel, Qualcomm, Caterpillar and many others.
- Secure: the fact that the Mongoose Library is used by NASA aboard the International Space Station is the best confirmation to it.
# Mongoose is used to implement
Mongoose is embedded in the software, machinery, devices, appliances to implement:
- Web UI interface on devices
- RESTful API services
- Telemetry data exchange
- Remote control for a product
- Remote software updates
- Remote monitoring
The Mongoose ecosystem is very dynamic and ever increasing.
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
2020-12-05 11:41:23 +00:00
on the top 9 things to avoid when embedding a web server.
- [Download “9 Things NOT to do when embedding a web server” white paper here](https://www.cesanta.com/whitepaper.html)
# Case Studies and Testimonials:
Testimonials:
- "Easily, Mongoose is one of the best web servers on the market. It has helped us to achieve the required level of performance with the seamless integration. It is very stable and we have not encountered any significant bugs." - Santhosh Kumar P.B, Lead Architect, Schneider Electric
- "Performance and stability of Mongoose Web Server are very good! We had no noticeable issues whatsoever!" - Linus Nuber, Software Architect, Schenck Process Europe GmbH
- "We looked through many different libraries and solutions, but with the Mongoose Web Server Library just within a couple of hours, we built a proof of concept. Everything just works, we faced no problems with Mongoose." Samuel Remy, Project Engineer, HAENNI Instruments Inc.
[See Testimonials](https://www.cesanta.com/testimonials.html)
Case Studies:
- Schneider Electric integrated Mongoose Web Server Library in “Automation Runtimes” - a specialized distributed control system.
- Schenck Process integrated Mongoose Web Server Library in the “DISOMAT Tersus” weighing terminal.
- HAENNI Instruments used Mongoose to enable communication with the "HAENNI Wheel Load Scales" - a low weight, robust, long lasting wheel load scales.
[See Case Studies](https://www.cesanta.com/case-studies.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
# 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)
- [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
# 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
* 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
# Licensing
Mongoose is released under Commercial and [GNU GPL v.2](http://www.gnu.org/licenses/old-licenses/gpl-2.0.html) open source licenses.
Commercial Projects: [Contact us for commercial license.](https://www.cesanta.com/contact.html)
2015-08-18 09:50:00 +01:00
# Dashboard Example
2014-03-11 16:59:17 +00: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:
![](http://www.cesanta.com/images/dashboard.png)
2014-03-11 16:59:17 +00: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
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