A library for talking to Multi-Tech's Cellular SocketModem Devices.
Dependents: M2X_dev axeda_wrapper_dev MTS_M2x_Example1 MTS_Cellular_Connect_Example ... more
io/IPStack.h@139:73a7d1cd2e9c, 2014-01-04 (annotated)
- Committer:
- jengbrecht
- Date:
- Sat Jan 04 04:22:29 2014 +0000
- Revision:
- 139:73a7d1cd2e9c
- Parent:
- 46:b30547bf07d5
- Child:
- 141:571e0ef6c8dc
Removed UDP support from Socket Package and noted this in documentation within IPStack, Cellular and Wifi classes.
Who changed what in which revision?
User | Revision | Line number | New contents of line |
---|---|---|---|
sgodinez | 11:134435d8a2d5 | 1 | #ifndef IPSTACK_H |
sgodinez | 11:134435d8a2d5 | 2 | #define IPSTACK_H |
sgodinez | 11:134435d8a2d5 | 3 | |
sgodinez | 11:134435d8a2d5 | 4 | #include <string> |
sgodinez | 11:134435d8a2d5 | 5 | |
mfiore | 39:6e94520a3217 | 6 | namespace mts { |
mfiore | 40:14342c4de476 | 7 | |
jengbrecht | 36:bb6b293c7495 | 8 | /** This class is a pure virtual class that should be inherited from when implementing |
jengbrecht | 36:bb6b293c7495 | 9 | * a communications device with an onboard IP stack. Examples of this would be a Wi-Fi |
jengbrecht | 36:bb6b293c7495 | 10 | * or Cellular radio with a built in IP stack. Typically the IP functionality in these |
jengbrecht | 36:bb6b293c7495 | 11 | * devices is available through an AT or a similiar command interface. The inheriting |
jengbrecht | 36:bb6b293c7495 | 12 | * class should map the device commands and functionality to the pure virtual methods provided |
jengbrecht | 36:bb6b293c7495 | 13 | * here. There should also be at least one or more calls to setup the communication link |
jengbrecht | 36:bb6b293c7495 | 14 | * specific paramters as an init method for example. This would do things like configure |
jengbrecht | 36:bb6b293c7495 | 15 | * the APN in a cellular radio or set the ssid for a WiFi device, which cannot be accounted |
jengbrecht | 36:bb6b293c7495 | 16 | * for in an abstract class like this one. |
jengbrecht | 27:8e6188cbcfd4 | 17 | */ |
sgodinez | 11:134435d8a2d5 | 18 | class IPStack |
sgodinez | 11:134435d8a2d5 | 19 | { |
sgodinez | 11:134435d8a2d5 | 20 | public: |
jengbrecht | 36:bb6b293c7495 | 21 | /// An enumeration for selecting the Socket Mode of TCP or UDP. |
sgodinez | 11:134435d8a2d5 | 22 | enum Mode { |
sgodinez | 11:134435d8a2d5 | 23 | TCP, UDP |
sgodinez | 11:134435d8a2d5 | 24 | }; |
sgodinez | 11:134435d8a2d5 | 25 | |
jengbrecht | 36:bb6b293c7495 | 26 | /** This method is used to connect the IP layer and below for the interface. Required |
jengbrecht | 27:8e6188cbcfd4 | 27 | * configurations and settings should be done in other calls or an init function. |
jengbrecht | 27:8e6188cbcfd4 | 28 | * |
jengbrecht | 36:bb6b293c7495 | 29 | * @returns true if the connection was successfully established, otherwise false. |
jengbrecht | 27:8e6188cbcfd4 | 30 | */ |
jengbrecht | 27:8e6188cbcfd4 | 31 | virtual bool connect() = 0; |
jengbrecht | 27:8e6188cbcfd4 | 32 | |
jengbrecht | 36:bb6b293c7495 | 33 | /** This method is used to disconnect the IP layer and below of the interface. This includes |
jengbrecht | 27:8e6188cbcfd4 | 34 | * any cleanup required before another connection can be made. |
jengbrecht | 27:8e6188cbcfd4 | 35 | */ |
sgodinez | 11:134435d8a2d5 | 36 | virtual void disconnect() = 0; |
jengbrecht | 27:8e6188cbcfd4 | 37 | |
jengbrecht | 36:bb6b293c7495 | 38 | /** This method is used to check if the IP layer of the interface is currently connected. |
jengbrecht | 27:8e6188cbcfd4 | 39 | * |
jengbrecht | 27:8e6188cbcfd4 | 40 | * @returns true if currently connected, otherwise false. |
jengbrecht | 27:8e6188cbcfd4 | 41 | */ |
sgodinez | 11:134435d8a2d5 | 42 | virtual bool isConnected() = 0; |
sgodinez | 11:134435d8a2d5 | 43 | |
jengbrecht | 27:8e6188cbcfd4 | 44 | /** This method is used to set the local port for the UDP or TCP socket connection. |
jengbrecht | 27:8e6188cbcfd4 | 45 | * The connection can be made using the open method. |
jengbrecht | 27:8e6188cbcfd4 | 46 | * |
jengbrecht | 27:8e6188cbcfd4 | 47 | * @param port the local port of the socket as an int. |
jengbrecht | 27:8e6188cbcfd4 | 48 | */ |
sgodinez | 11:134435d8a2d5 | 49 | virtual bool bind(unsigned int port) = 0; |
jengbrecht | 36:bb6b293c7495 | 50 | |
jengbrecht | 27:8e6188cbcfd4 | 51 | /** This method is used to open a socket connection with the given parameters. |
jengbrecht | 27:8e6188cbcfd4 | 52 | * This socket connection is established using the devices built in IP stack. |
jengbrecht | 139:73a7d1cd2e9c | 53 | * Currently TCP is the only supported mode. |
jengbrecht | 27:8e6188cbcfd4 | 54 | * |
jengbrecht | 36:bb6b293c7495 | 55 | * @param address is the address you want to connect to in the form of xxx.xxx.xxx.xxx |
jengbrecht | 45:40745c2036cf | 56 | * or a URL. If using a URL make sure the device supports DNS and is properly configured |
jengbrecht | 45:40745c2036cf | 57 | * for that mode. |
jengbrecht | 27:8e6188cbcfd4 | 58 | * @param port the remote port you want to connect to. |
jengbrecht | 36:bb6b293c7495 | 59 | * @param mode an enum that specifies whether this socket connection is type TCP or UDP. |
jengbrecht | 139:73a7d1cd2e9c | 60 | * Currently only TCP is supported. |
jengbrecht | 27:8e6188cbcfd4 | 61 | * @returns true if the connection was successfully opened, otherwise false. |
jengbrecht | 27:8e6188cbcfd4 | 62 | */ |
sgodinez | 11:134435d8a2d5 | 63 | virtual bool open(const std::string& address, unsigned int port, Mode mode) = 0; |
jengbrecht | 36:bb6b293c7495 | 64 | |
jengbrecht | 36:bb6b293c7495 | 65 | /** This method is used to determine if a socket connection is currently open. |
jengbrecht | 27:8e6188cbcfd4 | 66 | * |
jengbrecht | 27:8e6188cbcfd4 | 67 | * @returns true if the socket is currently open, otherwise false. |
jengbrecht | 27:8e6188cbcfd4 | 68 | */ |
sgodinez | 11:134435d8a2d5 | 69 | virtual bool isOpen() = 0; |
jengbrecht | 36:bb6b293c7495 | 70 | |
jengbrecht | 27:8e6188cbcfd4 | 71 | /** This method is used to close a socket connection that is currently open. |
jengbrecht | 27:8e6188cbcfd4 | 72 | * |
jengbrecht | 27:8e6188cbcfd4 | 73 | * @returns true if successfully closed, otherwise returns false on an error. |
jengbrecht | 27:8e6188cbcfd4 | 74 | */ |
sgodinez | 17:2d7c4ea7491b | 75 | virtual bool close() = 0; |
jengbrecht | 27:8e6188cbcfd4 | 76 | |
jengbrecht | 36:bb6b293c7495 | 77 | /** This method is used to read data off of a socket, assuming a valid socket |
jengbrecht | 36:bb6b293c7495 | 78 | * connection is already open. |
jengbrecht | 36:bb6b293c7495 | 79 | * |
jengbrecht | 36:bb6b293c7495 | 80 | * @param data a pointer to the data buffer that will be filled with the read data. |
jengbrecht | 36:bb6b293c7495 | 81 | * @param max the maximum number of bytes to attempt to read, typically the same as |
jengbrecht | 45:40745c2036cf | 82 | * the size of the passed in data buffer. |
jengbrecht | 36:bb6b293c7495 | 83 | * @param timeout the amount of time in milliseconds to wait in trying to read the max |
jengbrecht | 36:bb6b293c7495 | 84 | * number of bytes. If set to -1 the call blocks until it receives the max number of bytes |
jengbrecht | 36:bb6b293c7495 | 85 | * or encounters and error. |
jengbrecht | 36:bb6b293c7495 | 86 | * @returns the number of bytes read and stored in the passed in data buffer. Returns |
jengbrecht | 36:bb6b293c7495 | 87 | * -1 if there was an error in reading. |
jengbrecht | 36:bb6b293c7495 | 88 | */ |
sgodinez | 11:134435d8a2d5 | 89 | virtual int read(char* data, int max, int timeout = -1) = 0; |
jengbrecht | 36:bb6b293c7495 | 90 | |
jengbrecht | 36:bb6b293c7495 | 91 | /** This method is used to write data to a socket, assuming a valid socket |
jengbrecht | 36:bb6b293c7495 | 92 | * connection is already open. |
jengbrecht | 36:bb6b293c7495 | 93 | * |
jengbrecht | 36:bb6b293c7495 | 94 | * @param data a pointer to the data buffer that will be written to the socket. |
jengbrecht | 36:bb6b293c7495 | 95 | * @param length the size of the data buffer to be written. |
jengbrecht | 36:bb6b293c7495 | 96 | * @param timeout the amount of time in milliseconds to wait in trying to write the entire |
jengbrecht | 36:bb6b293c7495 | 97 | * number of bytes. If set to -1 the call blocks until it writes all of the bytes or |
jengbrecht | 36:bb6b293c7495 | 98 | * encounters and error. |
jengbrecht | 36:bb6b293c7495 | 99 | * @returns the number of bytes written to the socket's write buffer. Returns |
jengbrecht | 36:bb6b293c7495 | 100 | * -1 if there was an error in writing. |
jengbrecht | 36:bb6b293c7495 | 101 | */ |
sgodinez | 41:81d035fb0b6a | 102 | virtual int write(const char* data, int length, int timeout = -1) = 0; |
sgodinez | 44:86fa8f50a1df | 103 | |
jengbrecht | 27:8e6188cbcfd4 | 104 | |
jengbrecht | 27:8e6188cbcfd4 | 105 | /** This method is used to get the number of bytes available to read off the |
jengbrecht | 27:8e6188cbcfd4 | 106 | * socket. |
jengbrecht | 27:8e6188cbcfd4 | 107 | * |
jengbrecht | 27:8e6188cbcfd4 | 108 | * @returns the number of bytes available, 0 if there are no bytes to read. |
jengbrecht | 27:8e6188cbcfd4 | 109 | */ |
sgodinez | 11:134435d8a2d5 | 110 | virtual unsigned int readable() = 0; |
jengbrecht | 36:bb6b293c7495 | 111 | |
jengbrecht | 27:8e6188cbcfd4 | 112 | /** This method is used to get the space available to write bytes to the socket. |
jengbrecht | 27:8e6188cbcfd4 | 113 | * |
jengbrecht | 45:40745c2036cf | 114 | * @returns the number of bytes that can be written, 0 if unable to write. |
jengbrecht | 27:8e6188cbcfd4 | 115 | */ |
sgodinez | 11:134435d8a2d5 | 116 | virtual unsigned int writeable() = 0; |
jengbrecht | 27:8e6188cbcfd4 | 117 | |
jengbrecht | 36:bb6b293c7495 | 118 | /** This method is used to reset the device that provides the communications |
jengbrecht | 36:bb6b293c7495 | 119 | * capability. Note that you may have to wait some time after reset before the |
jengbrecht | 36:bb6b293c7495 | 120 | * device can be used. |
jengbrecht | 27:8e6188cbcfd4 | 121 | */ |
sgodinez | 11:134435d8a2d5 | 122 | virtual void reset() = 0; |
sgodinez | 11:134435d8a2d5 | 123 | }; |
sgodinez | 11:134435d8a2d5 | 124 | |
mfiore | 39:6e94520a3217 | 125 | } |
mfiore | 39:6e94520a3217 | 126 | |
sgodinez | 11:134435d8a2d5 | 127 | #endif /* IPSTACK_H */ |