mirror of https://github.com/jetkvm/kvm.git
				
				
				
			Compare commits
	
		
			No commits in common. "58c5875aa74820bd51dd31b423d3d72617f30645" and "382c07b87afec8aec02630ebc0623f51c002e69e" have entirely different histories.
		
	
	
		
			58c5875aa7
			...
			382c07b87a
		
	
		
							
								
								
									
										20
									
								
								config.go
								
								
								
								
							
							
						
						
									
										20
									
								
								config.go
								
								
								
								
							|  | @ -12,11 +12,11 @@ type WakeOnLanDevice struct { | |||
| } | ||||
| 
 | ||||
| type UsbConfig struct { | ||||
| 	VendorId     string `json:"vendor_id"` | ||||
| 	ProductId    string `json:"product_id"` | ||||
| 	SerialNumber string `json:"serial_number"` | ||||
| 	Manufacturer string `json:"manufacturer"` | ||||
| 	Product      string `json:"product"` | ||||
| 	UsbVendorId     string `json:"usb_vendor_id"` | ||||
| 	UsbProductId    string `json:"usb_product_id"` | ||||
| 	UsbSerialNumber string `json:"usb_serial_number"` | ||||
| 	UsbManufacturer string `json:"usb_manufacturer"` | ||||
| 	UsbProduct      string `json:"usb_product"` | ||||
| } | ||||
| 
 | ||||
| type Config struct { | ||||
|  | @ -39,11 +39,11 @@ var defaultConfig = &Config{ | |||
| 	CloudURL:          "https://api.jetkvm.com", | ||||
| 	AutoUpdateEnabled: true, // Set a default value
 | ||||
| 	UsbConfig: UsbConfig{ | ||||
| 		VendorId:     "0x1d6b", //The Linux Foundation
 | ||||
| 		ProductId:    "0x0104", //Multifunction Composite Gadget¬
 | ||||
| 		SerialNumber: "", | ||||
| 		Manufacturer: "JetKVM", | ||||
| 		Product:      "JetKVM USB Emulation Device", | ||||
| 		UsbVendorId:     "0x1d6b", //The Linux Foundation
 | ||||
| 		UsbProductId:    "0x0104", //Multifunction Composite Gadget¬
 | ||||
| 		UsbSerialNumber: "", | ||||
| 		UsbManufacturer: "JetKVM", | ||||
| 		UsbProduct:      "JetKVM USB Emulation Device", | ||||
| 	}, | ||||
| } | ||||
| 
 | ||||
|  |  | |||
|  | @ -13,7 +13,7 @@ export interface UsbConfigState { | |||
|   product_id: string; | ||||
|   serial_number: string; | ||||
|   manufacturer: string; | ||||
|   product: string; | ||||
|   product_name: string; | ||||
| } | ||||
| 
 | ||||
| export default function USBConfigDialog({ | ||||
|  | @ -79,11 +79,11 @@ function UpdateUsbConfigModal({ | |||
|   error: string | null; | ||||
| }) { | ||||
|   const [usbConfig, setUsbConfig] = useState({ | ||||
|     vendor_id: '', | ||||
|     product_id: '', | ||||
|     serial_number: '', | ||||
|     manufacturer: '', | ||||
|     product: '', | ||||
|     usb_vendor_id: '', | ||||
|     usb_product_id: '', | ||||
|     usb_serial_number: '', | ||||
|     usb_manufacturer: '', | ||||
|     usb_product: '', | ||||
|   }) | ||||
| 
 | ||||
|   const [usbConfigState, setUsbConfigState] = useState<UsbConfigState>(); | ||||
|  | @ -91,10 +91,11 @@ function UpdateUsbConfigModal({ | |||
| 
 | ||||
|   const syncUsbConfig = useCallback(() => { | ||||
|     send("getUsbConfig", {}, resp => { | ||||
|       if ("error" in resp) { | ||||
|         console.error("Failed to load USB Config:", resp.error); | ||||
|       } else { | ||||
|       if ("result" in resp) { | ||||
|         console.info("Successfully synced USB Config: ", resp.result); | ||||
|         setUsbConfigState(resp.result as UsbConfigState); | ||||
|       } else { | ||||
|         console.error("Failed to load USB Config:", resp.error); | ||||
|       } | ||||
|     }); | ||||
|   }, [send, setUsbConfigState]); | ||||
|  | @ -104,24 +105,24 @@ function UpdateUsbConfigModal({ | |||
|     syncUsbConfig(); | ||||
|   }, [syncUsbConfig]); | ||||
| 
 | ||||
|   const handleUsbVendorIdChange = (value: string) => { | ||||
|     setUsbConfig({... usbConfig, vendor_id: value}) | ||||
|   const handleUsbVendorIdChange = (vendorId: string) => { | ||||
|     setUsbConfig({... usbConfig, usb_vendor_id: vendorId}) | ||||
|   }; | ||||
| 
 | ||||
|   const handleUsbProductIdChange = (value: string) => { | ||||
|     setUsbConfig({... usbConfig, product_id: value}) | ||||
|   const handleUsbProductIdChange = (productId: string) => { | ||||
|     setUsbConfig({... usbConfig, usb_product_id: productId}) | ||||
|   }; | ||||
| 
 | ||||
|   const handleUsbSerialChange = (value: string) => { | ||||
|     setUsbConfig({... usbConfig, serial_number: value}) | ||||
|   const handleUsbSerialChange = (serialNumber: string) => { | ||||
|     setUsbConfig({... usbConfig, usb_serial_number: serialNumber}) | ||||
|   }; | ||||
| 
 | ||||
|   const handleUsbManufacturer = (value: string) => { | ||||
|     setUsbConfig({... usbConfig, manufacturer: value}) | ||||
|   const handleUsbManufacturer = (manufacturer: string) => { | ||||
|     setUsbConfig({... usbConfig, usb_manufacturer: manufacturer}) | ||||
|   }; | ||||
| 
 | ||||
|   const handleUsbProduct = (value: string) => { | ||||
|     setUsbConfig({... usbConfig, product: value}) | ||||
|   const handleUsbProduct = (name: string) => { | ||||
|     setUsbConfig({... usbConfig, usb_product: name}) | ||||
|   }; | ||||
| 
 | ||||
|   return ( | ||||
|  | @ -142,37 +143,35 @@ function UpdateUsbConfigModal({ | |||
|           required | ||||
|           label="Vendor ID" | ||||
|           placeholder="Enter Vendor ID" | ||||
|           pattern="^0[xX][\da-fA-F]{4}$" | ||||
|           defaultValue={usbConfigState?.vendor_id} | ||||
|           value={usbConfigState?.vendor_id} | ||||
|           onChange={e => handleUsbVendorIdChange(e.target.value)} | ||||
|         /> | ||||
|         <InputFieldWithLabel | ||||
|           required | ||||
|           label="Product ID" | ||||
|           placeholder="Enter Product ID" | ||||
|           pattern="^0[xX][\da-fA-F]{4}$" | ||||
|           defaultValue={usbConfigState?.product_id} | ||||
|           value={usbConfigState?.product_id} | ||||
|           onChange={e => handleUsbProductIdChange(e.target.value)} | ||||
|         /> | ||||
|         <InputFieldWithLabel | ||||
|           required | ||||
|           label="Serial Number" | ||||
|           placeholder="Enter Serial Number" | ||||
|           defaultValue={usbConfigState?.serial_number} | ||||
|           value={usbConfigState?.serial_number} | ||||
|           onChange={e => handleUsbSerialChange(e.target.value)} | ||||
|         /> | ||||
|         <InputFieldWithLabel | ||||
|           required | ||||
|           label="Manufacturer" | ||||
|           placeholder="Enter Manufacturer" | ||||
|           defaultValue={usbConfigState?.manufacturer} | ||||
|           value={usbConfigState?.manufacturer} | ||||
|           onChange={e => handleUsbManufacturer(e.target.value)} | ||||
|         /> | ||||
|         <InputFieldWithLabel | ||||
|           required | ||||
|           label="Product Name" | ||||
|           placeholder="Enter Product Name" | ||||
|           defaultValue={usbConfigState?.product} | ||||
|           value={usbConfigState?.product_name} | ||||
|           onChange={e => handleUsbProduct(e.target.value)} | ||||
|         /> | ||||
|         <div className="flex gap-x-2"> | ||||
|  |  | |||
							
								
								
									
										18
									
								
								usb.go
								
								
								
								
							
							
						
						
									
										18
									
								
								usb.go
								
								
								
								
							|  | @ -61,8 +61,8 @@ func init() { | |||
| func UpdateGadgetConfig() error { | ||||
| 	LoadConfig() | ||||
| 	gadgetAttrs := [][]string{ | ||||
| 		{"idVendor", config.UsbConfig.VendorId}, | ||||
| 		{"idProduct", config.UsbConfig.ProductId}, | ||||
| 		{"idVendor", config.UsbConfig.UsbVendorId}, | ||||
| 		{"idProduct", config.UsbConfig.UsbProductId}, | ||||
| 	} | ||||
| 	err := writeGadgetAttrs(kvmGadgetPath, gadgetAttrs) | ||||
| 	if err != nil { | ||||
|  | @ -72,9 +72,9 @@ func UpdateGadgetConfig() error { | |||
| 	log.Printf("Successfully updated usb gadget attributes: %v", gadgetAttrs) | ||||
| 
 | ||||
| 	strAttrs := [][]string{ | ||||
| 		{"serialnumber", config.UsbConfig.SerialNumber}, | ||||
| 		{"manufacturer", config.UsbConfig.Manufacturer}, | ||||
| 		{"product", config.UsbConfig.Product}, | ||||
| 		{"serialnumber", config.UsbConfig.UsbSerialNumber}, | ||||
| 		{"manufacturer", config.UsbConfig.UsbManufacturer}, | ||||
| 		{"product", config.UsbConfig.UsbProduct}, | ||||
| 	} | ||||
| 	gadgetStringsPath := filepath.Join(kvmGadgetPath, "strings", "0x409") | ||||
| 	err = os.MkdirAll(gadgetStringsPath, 0755) | ||||
|  | @ -120,8 +120,8 @@ func writeGadgetConfig() error { | |||
| 	LoadConfig() | ||||
| 	err = writeGadgetAttrs(kvmGadgetPath, [][]string{ | ||||
| 		{"bcdUSB", "0x0200"}, //USB 2.0
 | ||||
| 		{"idVendor", config.UsbConfig.VendorId}, | ||||
| 		{"idProduct", config.UsbConfig.ProductId}, | ||||
| 		{"idVendor", config.UsbConfig.UsbVendorId}, | ||||
| 		{"idProduct", config.UsbConfig.UsbProductId}, | ||||
| 		{"bcdDevice", "0100"}, | ||||
| 	}) | ||||
| 	if err != nil { | ||||
|  | @ -136,8 +136,8 @@ func writeGadgetConfig() error { | |||
| 
 | ||||
| 	err = writeGadgetAttrs(gadgetStringsPath, [][]string{ | ||||
| 		{"serialnumber", GetDeviceID()}, | ||||
| 		{"manufacturer", config.UsbConfig.Manufacturer}, | ||||
| 		{"product", config.UsbConfig.Product}, | ||||
| 		{"manufacturer", config.UsbConfig.UsbManufacturer}, | ||||
| 		{"product", config.UsbConfig.UsbProduct}, | ||||
| 	}) | ||||
| 	if err != nil { | ||||
| 		return err | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue