Browse Source

Merge branch 'captFuture-AddingSIM7000E'

v_master
Sara Damiano 6 years ago
parent
commit
078cda3b2a
20 changed files with 1551 additions and 22 deletions
  1. +4
    -4
      examples/AllFunctions/AllFunctions.ino
  2. +1
    -1
      examples/BlynkClient/BlynkClient.ino
  3. +1
    -1
      examples/FileDownload/FileDownload.ino
  4. +1
    -1
      examples/HttpClient/HttpClient.ino
  5. +1
    -1
      examples/HttpsClient/HttpsClient.ino
  6. +1
    -1
      examples/MqttClient/MqttClient.ino
  7. +199
    -0
      examples/SIM7000-ESP32/AllFunctions/AllFunctions.ino
  8. +187
    -0
      examples/SIM7000-ESP32/Diagnostics/Diagnostics.ino
  9. +1
    -1
      examples/WebClient/WebClient.ino
  10. +1
    -1
      examples/more/Hologram_Dash/Hologram_Dash.ino
  11. +1
    -1
      examples/more/Industruino/Industruino.ino
  12. +1
    -1
      examples/more/SIM800_SslSetCert/SIM800_SslSetCert.ino
  13. +2
    -2
      library.json
  14. +1
    -1
      library.properties
  15. +9
    -2
      src/TinyGsmClient.h
  16. +1136
    -0
      src/TinyGsmClientSIM7000.h
  17. +1
    -1
      tools/AT_Debug/AT_Debug.ino
  18. +1
    -1
      tools/AT_Spy/AT_Spy.ino
  19. +1
    -1
      tools/Diagnostics/Diagnostics.ino
  20. +1
    -1
      tools/FactoryReset/FactoryReset.ino

+ 4
- 4
examples/AllFunctions/AllFunctions.ino View File

@ -1,7 +1,7 @@
/**************************************************************
*
* TinyGSM Getting Started guide:
* http://tiny.cc/tiny-gsm-readme
* https://tiny.cc/tinygsm-readme
*
* NOTE:
* Some of the functions may be unavailable for your modem.
@ -10,10 +10,10 @@
**************************************************************/
// Select your modem:
#define TINY_GSM_MODEM_SIM800
// #define TINY_GSM_MODEM_SIM900
//#define TINY_GSM_MODEM_SIM800
// #define TINY_GSM_MODEM_SIM808
// #define TINY_GSM_MODEM_SIM868
// #define TINY_GSM_MODEM_SIM900
#define TINY_GSM_MODEM_SIM7000
// #define TINY_GSM_MODEM_UBLOX
// #define TINY_GSM_MODEM_M95
// #define TINY_GSM_MODEM_BG96


+ 1
- 1
examples/BlynkClient/BlynkClient.ino View File

@ -4,7 +4,7 @@
* https://github.com/blynkkk/blynk-library/releases/latest
*
* TinyGSM Getting Started guide:
* http://tiny.cc/tiny-gsm-readme
* https://tiny.cc/tinygsm-readme
*
**************************************************************
*


+ 1
- 1
examples/FileDownload/FileDownload.ino View File

@ -5,7 +5,7 @@
* or from http://librarymanager/all#CRC32+checksum
*
* TinyGSM Getting Started guide:
* http://tiny.cc/tiny-gsm-readme
* https://tiny.cc/tinygsm-readme
*
* ATTENTION! Downloading big files requires of knowledge of
* the TinyGSM internals and some modem specifics,


+ 1
- 1
examples/HttpClient/HttpClient.ino View File

@ -8,7 +8,7 @@
* or from http://librarymanager/all#ArduinoHttpClient
*
* TinyGSM Getting Started guide:
* http://tiny.cc/tiny-gsm-readme
* https://tiny.cc/tinygsm-readme
*
* For more HTTP API examples, see ArduinoHttpClient library
*


+ 1
- 1
examples/HttpsClient/HttpsClient.ino View File

@ -8,7 +8,7 @@
* or from http://librarymanager/all#ArduinoHttpClient
*
* TinyGSM Getting Started guide:
* http://tiny.cc/tiny-gsm-readme
* https://tiny.cc/tinygsm-readme
*
* SSL/TLS is currently supported only with: SIM8xx, uBlox, ESP8266
*


+ 1
- 1
examples/MqttClient/MqttClient.ino View File

@ -5,7 +5,7 @@
* or from http://librarymanager/all#PubSubClient
*
* TinyGSM Getting Started guide:
* http://tiny.cc/tiny-gsm-readme
* https://tiny.cc/tinygsm-readme
*
* For more MQTT examples, see PubSubClient library
*


+ 199
- 0
examples/SIM7000-ESP32/AllFunctions/AllFunctions.ino View File

@ -0,0 +1,199 @@
/**************************************************************
*
* TinyGSM Getting Started guide:
* https://tiny.cc/tinygsm-readme
*
* NOTE:
* Some of the functions may be unavailable for your modem.
* Just comment them out.
*
**************************************************************/
// Select your modem:
//#define TINY_GSM_MODEM_SIM800
// #define TINY_GSM_MODEM_SIM808
// #define TINY_GSM_MODEM_SIM900
#define TINY_GSM_MODEM_SIM7000
// #define TINY_GSM_MODEM_UBLOX
// #define TINY_GSM_MODEM_BG96
// #define TINY_GSM_MODEM_A6
// #define TINY_GSM_MODEM_A7
// #define TINY_GSM_MODEM_M590
// Set serial for debug console (to the Serial Monitor, speed 115200)
#define SerialMon Serial
// Set serial for AT commands (to the module)
// Use Hardware Serial on Mega, Leonardo, Micro, ESP32
#include "HardwareSerial.h"
#define SerialAT Serial2
// or Software Serial on Uno, Nano
//#include <SoftwareSerial.h>
//SoftwareSerial SerialAT(2, 3); // RX, TX
#define MODEM_PWRKEY 18
//#define DUMP_AT_COMMANDS
#define TINY_GSM_DEBUG SerialMon
// Set phone numbers, if you want to test SMS and Calls
//#define SMS_TARGET "+4366066033403"
//#define CALL_TARGET "+43xxxxxx"
// Your GPRS credentials
// Leave empty, if missing user or pass
const char apn[] = "drei.at";
const char user[] = "";
const char pass[] = "";
#include <TinyGsmClient.h>
#ifdef DUMP_AT_COMMANDS
#include <StreamDebugger.h>
StreamDebugger debugger(SerialAT, SerialMon);
TinyGsm modem(debugger);
#else
TinyGsm modem(SerialAT);
TinyGsmClient client(modem);
#endif
void setup() {
// Set pwr pin 18 (ESP32) --> shield's PWRKEY
pinMode(MODEM_PWRKEY, OUTPUT);
powerOn(); //function for powering on SIM7000
// Set console baud rate
SerialMon.begin(115200);
delay(1000);
SerialAT.begin(9600);
delay(1000);
// Set GSM module baud rate
//TinyGsmAutoBaud(SerialAT);
}
void loop() {
// Restart takes quite some time
// To skip it, call init() instead of restart()
DBG("Initializing modem...");
if (!modem.restart()) {
delay(15000);
return;
}
//String modemInfo = modem.getModemInfo();
//DBG("Modem:", modemInfo);
// Unlock your SIM card with a PIN
//modem.simUnlock("1234");
// Network modes for SIM7000 (2-Automatic),(13-GSM Only),(38-LTE Only),(51-GSM And LTE Only)
String NetworkModes = modem.getNetworkModes();
DBG("Network Modes:", NetworkModes);
String NetworkMode = modem.setNetworkMode(0);
DBG("Changed Network Mode:", NetworkMode);
// Preferred LTE mode selection (1-Cat-M),(2-NB-IoT),(3-Cat-M And NB-IoT)
String PreferredModes = modem.getPreferredModes();
DBG("Preferred Modes:", PreferredModes);
String PreferredMode = modem.setPreferredMode(3);
DBG("Changed Preferred Mode:", PreferredMode);
/* DBG("Waiting for network...");
if (!modem.waitForNetwork()) {
delay(10000);
return;
}
if (modem.isNetworkConnected()) {
DBG("Network connected");
}*/
/*
DBG("Connecting to", apn);
if (!modem.gprsConnect(apn, user, pass)) {
delay(10000);
return;
}
bool res = modem.isGprsConnected();
DBG("GPRS status:", res ? "connected" : "not connected");
String ccid = modem.getSimCCID();
DBG("CCID:", ccid);
String imei = modem.getIMEI();
DBG("IMEI:", imei);
String cop = modem.getOperator();
DBG("Operator:", cop);
IPAddress local = modem.localIP();
DBG("Local IP:", local);
int csq = modem.getSignalQuality();
DBG("Signal quality:", csq);
// This is NOT supported on M590
int battLevel = modem.getBattPercent();
DBG("Battery lavel:", battLevel);
// This is only supported on SIMxxx series
float battVoltage = modem.getBattVoltage() / 1000.0F;
DBG("Battery voltage:", battVoltage);
// This is only supported on SIMxxx series
String gsmLoc = modem.getGsmLocation();
DBG("GSM location:", gsmLoc);
// This is only supported on SIMxxx series
String gsmTime = modem.getGSMDateTime(DATE_TIME);
DBG("GSM Time:", gsmTime);
String gsmDate = modem.getGSMDateTime(DATE_DATE);
DBG("GSM Date:", gsmDate);
modem.enableGPS();
String gps_raw = modem.getGPSraw();
modem.disableGPS();
DBG("GPS raw data:", gps_raw);
#if defined(SMS_TARGET)
res = modem.sendSMS(SMS_TARGET, String("Hello from ") + imei);
DBG("SMS:", res ? "OK" : "fail");
// This is only supported on SIMxxx series
res = modem.sendSMS_UTF16(SMS_TARGET, u"Привіііт!", 9);
DBG("UTF16 SMS:", res ? "OK" : "fail");
#endif
modem.gprsDisconnect();
if (!modem.isGprsConnected()) {
DBG("GPRS disconnected");
} else {
DBG("GPRS disconnect: Failed.");
}
*/
// Try to power-off (modem may decide to restart automatically)
// To turn off modem completely, please use Reset/Enable pins
modem.poweroff();
DBG("Poweroff.");
// Do nothing forevermore
while (true) {
modem.maintain();
}
}
void powerOn() {
digitalWrite(MODEM_PWRKEY, LOW);
delay(100);
digitalWrite(MODEM_PWRKEY, HIGH);
}

+ 187
- 0
examples/SIM7000-ESP32/Diagnostics/Diagnostics.ino View File

@ -0,0 +1,187 @@
/**************************************************************
*
* To run this tool you need StreamDebugger library:
* https://github.com/vshymanskyy/StreamDebugger
* or from http://librarymanager/all#StreamDebugger
*
* TinyGSM Getting Started guide:
* https://tiny.cc/tinygsm-readme
*
**************************************************************/
// Select your modem:
//#define TINY_GSM_MODEM_SIM800
// #define TINY_GSM_MODEM_SIM808
// #define TINY_GSM_MODEM_SIM900
#define TINY_GSM_MODEM_SIM7000
// #define TINY_GSM_MODEM_UBLOX
// #define TINY_GSM_MODEM_BG96
// #define TINY_GSM_MODEM_A6
// #define TINY_GSM_MODEM_A7
// #define TINY_GSM_MODEM_M590
// #define TINY_GSM_MODEM_ESP8266
// #define TINY_GSM_MODEM_XBEE
// Increase the buffer
#define TINY_GSM_RX_BUFFER 512
// Define the serial console for debug prints, if needed
//#define TINY_GSM_DEBUG Serial
#include <TinyGsmClient.h>
// Your GPRS credentials
// Leave empty, if missing user or pass
const char apn[] = "drei.at";
const char user[] = "";
const char pass[] = "";
// Set serial for debug console (to the Serial Monitor, speed 115200)
#define SerialMon Serial
// Set serial for AT commands (to the module)
// Use Hardware Serial on Mega, Leonardo, Micro, Esp32
#include "HardwareSerial.h"
#define SerialAT Serial2
// or Software Serial on Uno, Nano
//#include <SoftwareSerial.h>
//SoftwareSerial SerialAT(2, 3); // RX, TX
#include <StreamDebugger.h>
StreamDebugger debugger(SerialAT, SerialMon);
TinyGsm modem(debugger);
const char server[] = "vsh.pp.ua";
const char resource[] = "/TinyGSM/logo.txt";
const int port = 80;
TinyGsmClient client(modem);
// For SSL:
//const int port = 443;
//TinyGsmClientSecure client(modem);
void setup() {
// Set console baud rate
Serial.println("Starting Serial");
SerialMon.begin(115200);
delay(10);
// Set GSM module baud rate
SerialAT.begin(9600);
delay(3000);
}
void loop() {
// Restart takes quite some time
// To skip it, call init() instead of restart()
SerialMon.print("Initializing modem...");
if (!modem.restart()) {
SerialMon.println(F(" [fail]"));
SerialMon.println(F("************************"));
SerialMon.println(F(" Is your modem connected properly?"));
SerialMon.println(F(" Is your serial speed (baud rate) correct?"));
SerialMon.println(F(" Is your modem powered on?"));
SerialMon.println(F(" Do you use a good, stable power source?"));
SerialMon.println(F(" Try useing File -> Examples -> TinyGSM -> tools -> AT_Debug to find correct configuration"));
SerialMon.println(F("************************"));
delay(10000);
return;
}
SerialMon.println(F(" [OK]"));
String modemInfo = modem.getModemInfo();
SerialMon.print("Modem: ");
SerialMon.println(modemInfo);
// Unlock your SIM card with a PIN
//modem.simUnlock("1234");
SerialMon.print("Waiting for network...");
if (!modem.waitForNetwork()) {
SerialMon.println(F(" [fail]"));
SerialMon.println(F("************************"));
SerialMon.println(F(" Is your sim card locked?"));
SerialMon.println(F(" Do you have a good signal?"));
SerialMon.println(F(" Is antenna attached?"));
SerialMon.println(F(" Does the SIM card work with your phone?"));
SerialMon.println(F("************************"));
delay(10000);
return;
}
SerialMon.println(F(" [OK]"));
SerialMon.print("Connecting to ");
SerialMon.print(apn);
if (!modem.gprsConnect(apn, user, pass)) {
SerialMon.println(F(" [fail]"));
SerialMon.println(F("************************"));
SerialMon.println(F(" Is GPRS enabled by network provider?"));
SerialMon.println(F(" Try checking your card balance."));
SerialMon.println(F("************************"));
delay(10000);
return;
}
SerialMon.println(F(" [OK]"));
IPAddress local = modem.localIP();
SerialMon.print("Local IP: ");
SerialMon.println(local);
SerialMon.print(F("Connecting to "));
SerialMon.print(server);
if (!client.connect(server, port)) {
SerialMon.println(F(" [fail]"));
delay(10000);
return;
}
SerialMon.println(F(" [OK]"));
// Make a HTTP GET request:
client.print(String("GET ") + resource + " HTTP/1.0\r\n");
client.print(String("Host: ") + server + "\r\n");
client.print("Connection: close\r\n\r\n");
// Wait for data to arrive
while (client.connected() && !client.available()) {
delay(100);
SerialMon.print('.');
};
SerialMon.println();
// Skip all headers
client.find("\r\n\r\n");
// Read data
unsigned long timeout = millis();
unsigned long bytesReceived = 0;
while (client.connected() && millis() - timeout < 10000L) {
while (client.available()) {
char c = client.read();
//SerialMon.print(c);
bytesReceived += 1;
timeout = millis();
}
}
client.stop();
SerialMon.println(F("Server disconnected"));
modem.gprsDisconnect();
SerialMon.println(F("GPRS disconnected"));
SerialMon.println();
SerialMon.println(F("************************"));
SerialMon.print (F(" Received: "));
SerialMon.print(bytesReceived);
SerialMon.println(F(" bytes"));
SerialMon.print (F(" Test: "));
SerialMon.println((bytesReceived == 121) ? "PASSED" : "FAILED");
SerialMon.println(F("************************"));
// Do nothing forevermore
while (true) {
delay(1000);
}
}

+ 1
- 1
examples/WebClient/WebClient.ino View File

@ -4,7 +4,7 @@
* It can be used to perform HTTP/RESTful API calls.
*
* TinyGSM Getting Started guide:
* http://tiny.cc/tiny-gsm-readme
* https://tiny.cc/tinygsm-readme
*
**************************************************************/


+ 1
- 1
examples/more/Hologram_Dash/Hologram_Dash.ino View File

@ -4,7 +4,7 @@
* It can be used to perform HTTP/RESTful API calls.
*
* TinyGSM Getting Started guide:
* http://tiny.cc/tiny-gsm-readme
* https://tiny.cc/tinygsm-readme
*
**************************************************************/


+ 1
- 1
examples/more/Industruino/Industruino.ino View File

@ -8,7 +8,7 @@
* or from http://librarymanager/all#ArduinoHttpClient
*
* TinyGSM Getting Started guide:
* http://tiny.cc/tiny-gsm-readme
* https://tiny.cc/tinygsm-readme
*
* For more HTTP API examples, see ArduinoHttpClient library
*


+ 1
- 1
examples/more/SIM800_SslSetCert/SIM800_SslSetCert.ino View File

@ -3,7 +3,7 @@
* This sketch uploads SSL certificates to the SIM8xx
*
* TinyGSM Getting Started guide:
* http://tiny.cc/tiny-gsm-readme
* https://tiny.cc/tinygsm-readme
*
**************************************************************/


+ 2
- 2
library.json View File

@ -1,8 +1,8 @@
{
"name": "TinyGSM",
"version": "0.4.7",
"version": "0.5.0",
"description": "A small Arduino library for GPRS modules, that just works. Includes examples for Blynk, MQTT, File Download, and Web Client. Supports many GSM and wifi modules with AT command interfaces.",
"keywords": "GSM, AT commands, AT, SIM800, SIM900, A6, A7, M590, ESP8266, SIM800A, SIM800C, SIM800L, SIM800H, SIM808, SIM868, SIM900A, SIM900D, SIM908, SIM968, M95, MC60, MC60E, BG96, ublox",
"keywords": "GSM, AT commands, AT, SIM800, SIM900, A6, A7, M590, ESP8266, SIM7000, SIM800A, SIM800C, SIM800L, SIM800H, SIM808, SIM868, SIM900A, SIM900D, SIM908, SIM968, M95, MC60, MC60E, BG96, ublox",
"authors":
[
{


+ 1
- 1
library.properties View File

@ -1,5 +1,5 @@
name=TinyGSM
version=0.4.7
version=0.5.0
author=Volodymyr Shymanskyy
maintainer=Volodymyr Shymanskyy
sentence=A small Arduino library for GPRS modules, that just works.


+ 9
- 2
src/TinyGsmClient.h View File

@ -9,11 +9,11 @@
#ifndef TinyGsmClient_h
#define TinyGsmClient_h
#if defined(TINY_GSM_MODEM_SIM800) || defined(TINY_GSM_MODEM_SIM868) || defined(TINY_GSM_MODEM_UBLOX) || defined(TINY_GSM_MODEM_ESP8266)
#if defined(TINY_GSM_MODEM_SIM800) || defined(TINY_GSM_MODEM_SIM868) || defined(TINY_GSM_MODEM_UBLOX) || defined(TINY_GSM_MODEM_ESP8266) || defined(TINY_GSM_MODEM_SIM7000)
#define TINY_GSM_MODEM_HAS_SSL
#endif
#if defined(TINY_GSM_MODEM_SIM808) || defined(TINY_GSM_MODEM_SIM868) || defined(TINY_GSM_MODEM_A7) || defined(TINY_GSM_MODEM_MC60) || defined(TINY_GSM_MODEM_MC60E)
#if defined(TINY_GSM_MODEM_SIM808) || defined(TINY_GSM_MODEM_SIM868) || defined(TINY_GSM_MODEM_A7) || defined(TINY_GSM_MODEM_MC60) || defined(TINY_GSM_MODEM_MC60E) || defined(TINY_GSM_MODEM_SIM7000)
#define TINY_GSM_MODEM_HAS_GPS
#endif
@ -24,6 +24,13 @@
typedef TinyGsmSim800::GsmClient TinyGsmClient;
typedef TinyGsmSim800::GsmClientSecure TinyGsmClientSecure;
#elif defined(TINY_GSM_MODEM_SIM7000)
#define TINY_GSM_MODEM_HAS_GPRS
#include <TinyGsmClientSIM7000.h>
typedef TinyGsmSim7000 TinyGsm;
typedef TinyGsmSim7000::GsmClient TinyGsmClient;
typedef TinyGsmSim7000::GsmClientSecure TinyGsmClientSecure;
#elif defined(TINY_GSM_MODEM_SIM808) || defined(TINY_GSM_MODEM_SIM868)
#define TINY_GSM_MODEM_HAS_GPRS
#include <TinyGsmClientSIM808.h>


+ 1136
- 0
src/TinyGsmClientSIM7000.h
File diff suppressed because it is too large
View File


+ 1
- 1
tools/AT_Debug/AT_Debug.ino View File

@ -4,7 +4,7 @@
* and allows direct AT commands access
*
* TinyGSM Getting Started guide:
* http://tiny.cc/tiny-gsm-readme
* https://tiny.cc/tinygsm-readme
*
**************************************************************/


+ 1
- 1
tools/AT_Spy/AT_Spy.ino View File

@ -4,7 +4,7 @@
* between an Arduino and the modem.
*
* TinyGSM Getting Started guide:
* http://tiny.cc/tiny-gsm-readme
* https://tiny.cc/tinygsm-readme
*
**************************************************************/


+ 1
- 1
tools/Diagnostics/Diagnostics.ino View File

@ -5,7 +5,7 @@
* or from http://librarymanager/all#StreamDebugger
*
* TinyGSM Getting Started guide:
* http://tiny.cc/tiny-gsm-readme
* https://tiny.cc/tinygsm-readme
*
**************************************************************/


+ 1
- 1
tools/FactoryReset/FactoryReset.ino View File

@ -5,7 +5,7 @@
* or from http://librarymanager/all#StreamDebugger
*
* TinyGSM Getting Started guide:
* http://tiny.cc/tiny-gsm-readme
* https://tiny.cc/tinygsm-readme
*
**************************************************************/


Loading…
Cancel
Save