This repository has been archived on 2025-02-01. You can view files and clone it, but cannot push or open issues or pull requests.
reprapfirmware-dc42/Webserver.h
David Crocker e227dab386 Improvements to support Matt's web interface
Increase incoming web gcode buffer size to 1200 chars to allow more
gcodes to be sent in each message
Include free buffer size in poll response
Include response sequence number in poll response
Implement M30 (delete file) via USB interface
Support M503 and M111 commands via web interface
2014-01-27 18:15:46 +00:00

112 lines
3 KiB
C++

/****************************************************************************************************
RepRapFirmware - Webserver
This class serves a single-page web applications to the attached network. This page forms the user's
interface with the RepRap machine. This software interprests returned values from the page and uses it
to Generate G Codes, which it sends to the RepRap. It also collects values from the RepRap like
temperature and uses those to construct the web page.
The page itself - reprap.htm - uses Knockout.js and Jquery.js. See:
http://knockoutjs.com/
http://jquery.com/
-----------------------------------------------------------------------------------------------------
Version 0.2
10 May 2013
Adrian Bowyer
RepRap Professional Ltd
http://reprappro.com
Licence: GPL
****************************************************************************************************/
#ifndef WEBSERVER_H
#define WEBSERVER_H
#define KO_START "rr_"
#define KO_FIRST 3
#define POST_LENGTH 200
#define WEB_GCODE_LENGTH (1200) // max total length of gcodes we can accept in a single web request
class Webserver
{
public:
Webserver(Platform* p);
bool GCodeAvailable();
byte ReadGCode();
bool WebserverIsWriting();
void Init();
void Spin();
void Exit();
void Diagnostics();
void SetPassword(const char* pw);
void SetName(const char* nm);
void ConnectionError();
void HandleReply(const char *s, bool error);
void AppendReply(const char* s);
private:
void ParseClientLine();
void SendFile(const char* nameOfFileToSend);
void WriteByte();
void ParseQualifier();
void CheckPassword();
bool LoadGcodeBuffer(const char* gc, bool convertWeb);
void CloseClient();
bool PrintHeadString();
bool PrintLinkTable();
void GetGCodeList();
void GetJsonResponse(const char* request);
void ParseGetPost();
void CharFromClient(char c);
void BlankLineFromClient();
void InitialisePost();
bool MatchBoundary(char c);
void JsonReport(bool ok, const char* request);
Platform* platform;
bool active;
float lastTime;
float longWait;
FileStore* fileBeingSent;
bool writing;
bool receivingPost;
char postBoundary[POST_LENGTH];
int boundaryCount;
char postFileName[POST_LENGTH];
FileStore* postFile;
bool postSeen;
bool getSeen;
bool clientLineIsBlank;
float clientCloseTime;
bool needToCloseClient;
char clientLine[STRING_LENGTH];
char clientRequest[STRING_LENGTH];
char clientQualifier[STRING_LENGTH];
char jsonResponse[STRING_LENGTH+1];
char gcodeBuffer[WEB_GCODE_LENGTH+1];
int jsonPointer;
bool gcodeAvailable;
int gcodePointer;
int clientLinePointer;
bool gotPassword;
char password[SHORT_STRING_LENGTH+1];
char myName[SHORT_STRING_LENGTH+1];
char gcodeReply[STRING_LENGTH+1];
uint16_t seq; // reply sequence number, so that the client can tell if a reply is new or not
};
#endif