| 
									
										
										
										
											2023-01-27 13:37:20 -08:00
										 |  |  | // Copyright (c) Tailscale Inc & AUTHORS | 
					
						
							|  |  |  | // SPDX-License-Identifier: BSD-3-Clause | 
					
						
							| 
									
										
										
										
											2023-01-17 18:39:49 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-08-10 17:01:22 -07:00
										 |  |  | // Windows-specific stuff that can't go in clientupdate.go because it needs | 
					
						
							| 
									
										
										
										
											2023-01-17 18:39:49 -08:00
										 |  |  | // x/sys/windows. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-08-10 17:01:22 -07:00
										 |  |  | package clientupdate | 
					
						
							| 
									
										
										
										
											2023-01-17 18:39:49 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  | import ( | 
					
						
							|  |  |  | 	"golang.org/x/sys/windows" | 
					
						
							| 
									
										
										
										
											2023-08-10 17:01:22 -07:00
										 |  |  | 	"tailscale.com/util/winutil/authenticode" | 
					
						
							| 
									
										
										
										
											2023-01-17 18:39:49 -08:00
										 |  |  | ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func init() { | 
					
						
							|  |  |  | 	markTempFileFunc = markTempFileWindows | 
					
						
							| 
									
										
										
										
											2023-08-10 17:01:22 -07:00
										 |  |  | 	verifyAuthenticode = verifyTailscale | 
					
						
							| 
									
										
										
										
											2023-01-17 18:39:49 -08:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func markTempFileWindows(name string) error { | 
					
						
							|  |  |  | 	name16 := windows.StringToUTF16Ptr(name) | 
					
						
							|  |  |  | 	return windows.MoveFileEx(name16, nil, windows.MOVEFILE_DELAY_UNTIL_REBOOT) | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2023-08-10 17:01:22 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | const certSubjectTailscale = "Tailscale Inc." | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func verifyTailscale(path string) error { | 
					
						
							|  |  |  | 	return authenticode.Verify(path, certSubjectTailscale) | 
					
						
							|  |  |  | } |