mirror of
				https://github.com/juanfont/headscale.git
				synced 2025-10-26 13:41:05 +01:00 
			
		
		
		
	Merge pull request #278 from enoperm/pollnetmap-update-only
This commit is contained in:
		
						commit
						b122d06f12
					
				| @ -2,6 +2,9 @@ | |||||||
| 
 | 
 | ||||||
| **TBD (TBD):** | **TBD (TBD):** | ||||||
| 
 | 
 | ||||||
|  | - Fixed issue where hosts deleted from control server may be written back to the database, as long as they are connected to the control server [#278](https://github.com/juanfont/headscale/pull/278) | ||||||
|  |   ) | ||||||
|  | 
 | ||||||
| **0.12.3 (2022-01-13):** | **0.12.3 (2022-01-13):** | ||||||
| 
 | 
 | ||||||
| **Changes**: | **Changes**: | ||||||
|  | |||||||
| @ -319,6 +319,14 @@ func (h *Headscale) DeleteMachine(machine *Machine) error { | |||||||
| 	return h.RequestMapUpdates(namespaceID) | 	return h.RequestMapUpdates(namespaceID) | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | func (h *Headscale) TouchMachine(machine *Machine) error { | ||||||
|  | 	return h.db.Updates(Machine{ | ||||||
|  | 		ID:                   machine.ID, | ||||||
|  | 		LastSeen:             machine.LastSeen, | ||||||
|  | 		LastSuccessfulUpdate: machine.LastSuccessfulUpdate, | ||||||
|  | 	}).Error | ||||||
|  | } | ||||||
|  | 
 | ||||||
| // HardDeleteMachine hard deletes a Machine from the database. | // HardDeleteMachine hard deletes a Machine from the database. | ||||||
| func (h *Headscale) HardDeleteMachine(machine *Machine) error { | func (h *Headscale) HardDeleteMachine(machine *Machine) error { | ||||||
| 	err := h.RemoveSharedMachineFromAllNamespaces(machine) | 	err := h.RemoveSharedMachineFromAllNamespaces(machine) | ||||||
|  | |||||||
							
								
								
									
										84
									
								
								poll.go
									
									
									
									
									
								
							
							
						
						
									
										84
									
								
								poll.go
									
									
									
									
									
								
							| @ -102,7 +102,7 @@ func (h *Headscale) PollNetMapHandler(ctx *gin.Context) { | |||||||
| 		machine.Endpoints = datatypes.JSON(endpoints) | 		machine.Endpoints = datatypes.JSON(endpoints) | ||||||
| 		machine.LastSeen = &now | 		machine.LastSeen = &now | ||||||
| 	} | 	} | ||||||
| 	h.db.Save(&machine) | 	h.db.Updates(machine) | ||||||
| 
 | 
 | ||||||
| 	data, err := h.getMapResponse(machineKey, req, machine) | 	data, err := h.getMapResponse(machineKey, req, machine) | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| @ -291,6 +291,10 @@ func (h *Headscale) PollNetMapStream( | |||||||
| 					Str("channel", "pollData"). | 					Str("channel", "pollData"). | ||||||
| 					Err(err). | 					Err(err). | ||||||
| 					Msg("Cannot update machine from database") | 					Msg("Cannot update machine from database") | ||||||
|  | 
 | ||||||
|  | 				// client has been removed from database | ||||||
|  | 				// since the stream opened, terminate connection. | ||||||
|  | 				return false | ||||||
| 			} | 			} | ||||||
| 			now := time.Now().UTC() | 			now := time.Now().UTC() | ||||||
| 			machine.LastSeen = &now | 			machine.LastSeen = &now | ||||||
| @ -299,13 +303,22 @@ func (h *Headscale) PollNetMapStream( | |||||||
| 				Set(float64(now.Unix())) | 				Set(float64(now.Unix())) | ||||||
| 			machine.LastSuccessfulUpdate = &now | 			machine.LastSuccessfulUpdate = &now | ||||||
| 
 | 
 | ||||||
| 			h.db.Save(&machine) | 			err = h.TouchMachine(machine) | ||||||
| 			log.Trace(). | 			if err != nil { | ||||||
| 				Str("handler", "PollNetMapStream"). | 				log.Error(). | ||||||
| 				Str("machine", machine.Name). | 					Str("handler", "PollNetMapStream"). | ||||||
| 				Str("channel", "pollData"). | 					Str("machine", machine.Name). | ||||||
| 				Int("bytes", len(data)). | 					Str("channel", "pollData"). | ||||||
| 				Msg("Machine entry in database updated successfully after sending pollData") | 					Err(err). | ||||||
|  | 					Msg("Cannot update machine LastSuccessfulUpdate") | ||||||
|  | 			} else { | ||||||
|  | 				log.Trace(). | ||||||
|  | 					Str("handler", "PollNetMapStream"). | ||||||
|  | 					Str("machine", machine.Name). | ||||||
|  | 					Str("channel", "pollData"). | ||||||
|  | 					Int("bytes", len(data)). | ||||||
|  | 					Msg("Machine entry in database updated successfully after sending pollData") | ||||||
|  | 			} | ||||||
| 
 | 
 | ||||||
| 			return true | 			return true | ||||||
| 
 | 
 | ||||||
| @ -344,16 +357,29 @@ func (h *Headscale) PollNetMapStream( | |||||||
| 					Str("channel", "keepAlive"). | 					Str("channel", "keepAlive"). | ||||||
| 					Err(err). | 					Err(err). | ||||||
| 					Msg("Cannot update machine from database") | 					Msg("Cannot update machine from database") | ||||||
|  | 
 | ||||||
|  | 				// client has been removed from database | ||||||
|  | 				// since the stream opened, terminate connection. | ||||||
|  | 				return false | ||||||
| 			} | 			} | ||||||
| 			now := time.Now().UTC() | 			now := time.Now().UTC() | ||||||
| 			machine.LastSeen = &now | 			machine.LastSeen = &now | ||||||
| 			h.db.Save(&machine) | 			err = h.TouchMachine(machine) | ||||||
| 			log.Trace(). | 			if err != nil { | ||||||
| 				Str("handler", "PollNetMapStream"). | 				log.Error(). | ||||||
| 				Str("machine", machine.Name). | 					Str("handler", "PollNetMapStream"). | ||||||
| 				Str("channel", "keepAlive"). | 					Str("machine", machine.Name). | ||||||
| 				Int("bytes", len(data)). | 					Str("channel", "keepAlive"). | ||||||
| 				Msg("Machine updated successfully after sending keep alive") | 					Err(err). | ||||||
|  | 					Msg("Cannot update machine LastSeen") | ||||||
|  | 			} else { | ||||||
|  | 				log.Trace(). | ||||||
|  | 					Str("handler", "PollNetMapStream"). | ||||||
|  | 					Str("machine", machine.Name). | ||||||
|  | 					Str("channel", "keepAlive"). | ||||||
|  | 					Int("bytes", len(data)). | ||||||
|  | 					Msg("Machine updated successfully after sending keep alive") | ||||||
|  | 			} | ||||||
| 
 | 
 | ||||||
| 			return true | 			return true | ||||||
| 
 | 
 | ||||||
| @ -417,6 +443,10 @@ func (h *Headscale) PollNetMapStream( | |||||||
| 						Str("channel", "update"). | 						Str("channel", "update"). | ||||||
| 						Err(err). | 						Err(err). | ||||||
| 						Msg("Cannot update machine from database") | 						Msg("Cannot update machine from database") | ||||||
|  | 
 | ||||||
|  | 					// client has been removed from database | ||||||
|  | 					// since the stream opened, terminate connection. | ||||||
|  | 					return false | ||||||
| 				} | 				} | ||||||
| 				now := time.Now().UTC() | 				now := time.Now().UTC() | ||||||
| 
 | 
 | ||||||
| @ -424,7 +454,15 @@ func (h *Headscale) PollNetMapStream( | |||||||
| 					Set(float64(now.Unix())) | 					Set(float64(now.Unix())) | ||||||
| 				machine.LastSuccessfulUpdate = &now | 				machine.LastSuccessfulUpdate = &now | ||||||
| 
 | 
 | ||||||
| 				h.db.Save(&machine) | 				err = h.TouchMachine(machine) | ||||||
|  | 				if err != nil { | ||||||
|  | 					log.Error(). | ||||||
|  | 						Str("handler", "PollNetMapStream"). | ||||||
|  | 						Str("machine", machine.Name). | ||||||
|  | 						Str("channel", "update"). | ||||||
|  | 						Err(err). | ||||||
|  | 						Msg("Cannot update machine LastSuccessfulUpdate") | ||||||
|  | 				} | ||||||
| 			} else { | 			} else { | ||||||
| 				log.Trace(). | 				log.Trace(). | ||||||
| 					Str("handler", "PollNetMapStream"). | 					Str("handler", "PollNetMapStream"). | ||||||
| @ -452,10 +490,22 @@ func (h *Headscale) PollNetMapStream( | |||||||
| 					Str("channel", "Done"). | 					Str("channel", "Done"). | ||||||
| 					Err(err). | 					Err(err). | ||||||
| 					Msg("Cannot update machine from database") | 					Msg("Cannot update machine from database") | ||||||
|  | 
 | ||||||
|  | 				// client has been removed from database | ||||||
|  | 				// since the stream opened, terminate connection. | ||||||
|  | 				return false | ||||||
| 			} | 			} | ||||||
| 			now := time.Now().UTC() | 			now := time.Now().UTC() | ||||||
| 			machine.LastSeen = &now | 			machine.LastSeen = &now | ||||||
| 			h.db.Save(&machine) | 			err = h.TouchMachine(machine) | ||||||
|  | 			if err != nil { | ||||||
|  | 				log.Error(). | ||||||
|  | 					Str("handler", "PollNetMapStream"). | ||||||
|  | 					Str("machine", machine.Name). | ||||||
|  | 					Str("channel", "Done"). | ||||||
|  | 					Err(err). | ||||||
|  | 					Msg("Cannot update machine LastSeen") | ||||||
|  | 			} | ||||||
| 
 | 
 | ||||||
| 			log.Trace(). | 			log.Trace(). | ||||||
| 				Str("handler", "PollNetMapStream"). | 				Str("handler", "PollNetMapStream"). | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user