Fix wings receiving wrong suspended status on sync (#3667)
Due to wings pulling the server configuration rather than the Panel pushing it, wings gets the wrong status for a server if both the status update and sync request are ran in a transaction due to the status not being persisted in the database. Fixes #3639
This commit is contained in:
		
							parent
							
								
									de0d5c9b8a
								
							
						
					
					
						commit
						4fa38b8e9c
					
				| @ -58,15 +58,20 @@ class SuspensionService | |||||||
|             throw new ConflictHttpException('Cannot toggle suspension status on a server that is currently being transferred.'); |             throw new ConflictHttpException('Cannot toggle suspension status on a server that is currently being transferred.'); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         $this->connection->transaction(function () use ($action, $server, $isSuspending) { |         // Update the server's suspension status.
 | ||||||
|             $server->update([ |         $server->update([ | ||||||
|                 'status' => $isSuspending ? Server::STATUS_SUSPENDED : null, |             'status' => $isSuspending ? Server::STATUS_SUSPENDED : null, | ||||||
|             ]); |         ]); | ||||||
| 
 | 
 | ||||||
|             // Only trigger a Wings server sync if it is not currently being transferred.
 |         try { | ||||||
|             if (is_null($server->transfer)) { |             // Tell wings to re-sync the server state.
 | ||||||
|                 $this->daemonServerRepository->setServer($server)->sync(); |             $this->daemonServerRepository->setServer($server)->sync(); | ||||||
|             } |         } catch (\Exception $exception) { | ||||||
|         }); |             // Rollback the server's suspension status if wings fails to sync the server.
 | ||||||
|  |             $server->update([ | ||||||
|  |                 'status' => $isSuspending ? null : Server::STATUS_SUSPENDED, | ||||||
|  |             ]); | ||||||
|  |             throw $exception; | ||||||
|  |         } | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 Matthew Penner
						Matthew Penner