rework esp code en update py code
This commit is contained in:
		
							parent
							
								
									5e151e5bc2
								
							
						
					
					
						commit
						b03ec14c0f
					
				
							
								
								
									
										32
									
								
								recever.py
									
									
									
									
									
								
							
							
						
						
									
										32
									
								
								recever.py
									
									
									
									
									
								
							| @ -3,15 +3,24 @@ | |||||||
| import asyncio | import asyncio | ||||||
| from websockets.server import serve | from websockets.server import serve | ||||||
| 
 | 
 | ||||||
| pin = "1234" | adminId = "1234" | ||||||
| boats = ["999", "999", "999", "999"] | 
 | ||||||
|  | BOAT_STATE_INCTRL = 1 | ||||||
|  | BOAT_STATE_AVAILABLE = 0 | ||||||
|  | BOAT_STATE_LOCKED = -1 | ||||||
|  | 
 | ||||||
|  | boats = [ | ||||||
|  |     { "id": 0, "name": "test boat", "state": BOAT_STATE_AVAILABLE } | ||||||
|  | ] | ||||||
|  | 
 | ||||||
|  | clients = [] | ||||||
| 
 | 
 | ||||||
| def onCMD(data): | def onCMD(data): | ||||||
|     global boats, pin |     global boats, adminId | ||||||
|     print("command:" + str(data)) |     print("command:" + str(data)) | ||||||
|     if (len(data) != 4): |     if (len(data) != 4): | ||||||
|         return |         return | ||||||
|     if (data[1] != pin): |     if (data[1] != adminId): | ||||||
|         return |         return | ||||||
|     boot = int(data[2]) |     boot = int(data[2]) | ||||||
|     if (boot >= 0 and boot <= 3): |     if (boot >= 0 and boot <= 3): | ||||||
| @ -31,12 +40,21 @@ def onMessage(message): | |||||||
|         for boat in boats: |         for boat in boats: | ||||||
|             if(data[0] == boat): |             if(data[0] == boat): | ||||||
|                 sendData(data) |                 sendData(data) | ||||||
|                 break |                 break  | ||||||
|              | 
 | ||||||
|  | def newClient(message, ws): | ||||||
|  |     print("new client connected: " + message) | ||||||
|  |     return None | ||||||
| 
 | 
 | ||||||
| async def run(ws, path): | async def run(ws, path): | ||||||
|  |     client = {} | ||||||
|     async for message in ws: |     async for message in ws: | ||||||
|         onMessage(message) |         client = newClient(message, ws) | ||||||
|  |     if (client is None): | ||||||
|  |         return | ||||||
|  | 
 | ||||||
|  |     async for message in ws: | ||||||
|  |         onMessage(message, client) | ||||||
| 
 | 
 | ||||||
| async def main(): | async def main(): | ||||||
|     async with serve(run, "0.0.0.0", 8080): |     async with serve(run, "0.0.0.0", 8080): | ||||||
|  | |||||||
| @ -8,100 +8,13 @@ | |||||||
| WiFiUDP UDP; | WiFiUDP UDP; | ||||||
| #define RX_BUFFER_SIZE 255 | #define RX_BUFFER_SIZE 255 | ||||||
| char rxBuffer[RX_BUFFER_SIZE]; | char rxBuffer[RX_BUFFER_SIZE]; | ||||||
| uint8_t rxBuffer_writePointer = 0; | char lineBuffer[RX_BUFFER_SIZE]; | ||||||
| uint8_t rxBuffer_readPointer = 0; | uint8_t rxBuffer_readPointer = 0; | ||||||
|  | uint8_t rxBuffer_lineStart = 0; | ||||||
|  | uint8_t rxBuffer_lineEnd = 0; | ||||||
|  | bool unProcessedLineAvailable = false; | ||||||
| 
 | 
 | ||||||
| class FlipFlop_Buffer | bool rxBuffer_overflow = false; | ||||||
| { |  | ||||||
|   private: |  | ||||||
|     void *_buffer_flip; |  | ||||||
|     void *_buffer_flop; |  | ||||||
|     size_t _size; |  | ||||||
| 
 |  | ||||||
|     void *_active_buffer; |  | ||||||
|     void *_active_buffer_end; |  | ||||||
| 
 |  | ||||||
|     void *_write_head; |  | ||||||
| 
 |  | ||||||
|   public: |  | ||||||
| 
 |  | ||||||
|     Buffer(size_t size) |  | ||||||
|     { |  | ||||||
|       this->_size = size; |  | ||||||
|       this->_buffer_flip = maloc(size); |  | ||||||
|       this->_buffer_flop = maloc(size); |  | ||||||
| 
 |  | ||||||
|       this->_active_buffer = this->_buffer_flip; |  | ||||||
|       this->_active_buffer_end = this->_buffer_flip + this->_size; |  | ||||||
|     } |  | ||||||
|     ~Buffer() |  | ||||||
|     { |  | ||||||
|       free(this->_buffer_flip); |  | ||||||
|       free(this->_buffer_flop); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     bool put(void *data, size_t len) |  | ||||||
|     { |  | ||||||
|       bool sucsess; |  | ||||||
|       if (this->_write_head + len > this->_active_buffer_end) |  | ||||||
|       { |  | ||||||
|         memcpy(this->_write_head, data, this->_active_buffer_end - this->_write_head); |  | ||||||
|         this->_write_head = this._active_buffer_end; |  | ||||||
|         sucsess = false; |  | ||||||
|       } |  | ||||||
|       else |  | ||||||
|       { |  | ||||||
|         memcpy(this->write_p, data, len); |  | ||||||
|         this->_write_head += len; |  | ||||||
|         sucsess = true; |  | ||||||
|       } |  | ||||||
|       return sucsess; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     void swich_buffer() |  | ||||||
|     { |  | ||||||
|       if (this->_active_buffer == this->_buffer_flip) |  | ||||||
|       { |  | ||||||
|         this->_active_buffer = this->_buffer_flop; |  | ||||||
|       } |  | ||||||
|       else |  | ||||||
|       { |  | ||||||
|         this->_active_buffer == this->_buffer_flip; |  | ||||||
|       } |  | ||||||
|       this->_active_buffer_end = this._active_buffer + this._size; |  | ||||||
|       return; |  | ||||||
|     } |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| class LineFlip_Buffer : FlipFlop_Buffer  |  | ||||||
| { |  | ||||||
|   public: |  | ||||||
|     bool overrite put(void *data, size_t len) |  | ||||||
|     { |  | ||||||
|       bool justSwiched = false; |  | ||||||
|       bool sucsess = true; |  | ||||||
|       for (int i = 0; i < len; i++) |  | ||||||
|       { |  | ||||||
|         if (&(data + i) == '\n' || &(data + i) == '\r') |  | ||||||
|         { |  | ||||||
|           if (!justSwiched) |  | ||||||
|           { |  | ||||||
|             this->swich_buffer(); |  | ||||||
|             justSwiched = true; |  | ||||||
|           } |  | ||||||
|         } |  | ||||||
|         else |  | ||||||
|         { |  | ||||||
|           if(!FlipFlop_Buffer::put(data + i, 1)) |  | ||||||
|           { |  | ||||||
|             sucsess = false; |  | ||||||
|           } |  | ||||||
|           justSwiched = false; |  | ||||||
|         } |  | ||||||
|       } |  | ||||||
|       return sucsess |  | ||||||
|     } |  | ||||||
| } |  | ||||||
| 
 | 
 | ||||||
| void setup() { | void setup() { | ||||||
|   WiFi.begin(WIFI_SSID, WIFI_PASS); |   WiFi.begin(WIFI_SSID, WIFI_PASS); | ||||||
| @ -114,18 +27,35 @@ void setup() { | |||||||
|   UDP.begin(UDP_PORT); |   UDP.begin(UDP_PORT); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | void processLine() | ||||||
|  | { | ||||||
|  |   rxBuffer[rxBuffer_lineEnd] = 0; | ||||||
|  |   // what are the commands
 | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | int readNextLine() | ||||||
|  | { | ||||||
|  |   while (rxBuffer_readPointer < RX_BUFFER_SIZE) | ||||||
|  |   { | ||||||
|  |     if (rxBuffer[rxBuffer_readPointer] == '\n') | ||||||
|  |     { | ||||||
|  |       rxBuffer_lineEnd = rxBuffer_readPointer; | ||||||
|  |       processLine(); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     rxBuffer_readPointer++; | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | 
 | ||||||
| void loop() { | void loop() { | ||||||
|   int packetSize = UDP.parsePacket(); |   int packetSize = UDP.parsePacket(); | ||||||
|   if (packetSize) { |   if (packetSize) { | ||||||
|     int len = UDP.read(&rxBuffer[rxBuffer_writePointer], RX_BUFFER_SIZE-rxBuffer_writePointer); |     int len = UDP.read(&rxBuffer[0], RX_BUFFER_SIZE); | ||||||
|     if (rxBuffer_writePointer >= RX_BUFFER_SIZE) |  | ||||||
|     { |  | ||||||
|       rxBuffer_writePointer -= RX_BUFFER_SIZE; |  | ||||||
|     } |  | ||||||
|   } |  | ||||||
| 
 | 
 | ||||||
|   if (rxBuffer_writePointer != rxBuffer_readPointer) |     rxBuffer_readPointer = 0; | ||||||
|   { |     rxBuffer_lineStart = 0; | ||||||
|  |     rxBuffer_lineEnd = 0; | ||||||
| 
 | 
 | ||||||
|  |     readNextLine(); | ||||||
|   } |   } | ||||||
| } | } | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user