forked from Elara6331/infinitime
		
	Add local time characteristic (#4)
Co-authored-by: cybuzuma <cybuzuma@vnxs.de> Co-committed-by: cybuzuma <cybuzuma@vnxs.de>
This commit is contained in:
		| @@ -33,6 +33,7 @@ const ( | |||||||
| 	MotionValChar   = "00030002-78fc-48fe-8e23-433b3a1942d0" | 	MotionValChar   = "00030002-78fc-48fe-8e23-433b3a1942d0" | ||||||
| 	FirmwareVerChar = "00002a26-0000-1000-8000-00805f9b34fb" | 	FirmwareVerChar = "00002a26-0000-1000-8000-00805f9b34fb" | ||||||
| 	CurrentTimeChar = "00002a2b-0000-1000-8000-00805f9b34fb" | 	CurrentTimeChar = "00002a2b-0000-1000-8000-00805f9b34fb" | ||||||
|  | 	LocalTimeChar   = "00002a0f-0000-1000-8000-00805f9b34fb" | ||||||
| 	BatteryLvlChar  = "00002a19-0000-1000-8000-00805f9b34fb" | 	BatteryLvlChar  = "00002a19-0000-1000-8000-00805f9b34fb" | ||||||
| 	HeartRateChar   = "00002a37-0000-1000-8000-00805f9b34fb" | 	HeartRateChar   = "00002a37-0000-1000-8000-00805f9b34fb" | ||||||
| 	FSTransferChar  = "adaf0200-4669-6c65-5472-616e73666572" | 	FSTransferChar  = "adaf0200-4669-6c65-5472-616e73666572" | ||||||
| @@ -47,6 +48,7 @@ var charNames = map[string]string{ | |||||||
| 	MotionValChar:    "Motion Values", | 	MotionValChar:    "Motion Values", | ||||||
| 	FirmwareVerChar:  "Firmware Version", | 	FirmwareVerChar:  "Firmware Version", | ||||||
| 	CurrentTimeChar:  "Current Time", | 	CurrentTimeChar:  "Current Time", | ||||||
|  | 	LocalTimeChar:    "Local Time", | ||||||
| 	BatteryLvlChar:   "Battery Level", | 	BatteryLvlChar:   "Battery Level", | ||||||
| 	HeartRateChar:    "Heart Rate", | 	HeartRateChar:    "Heart Rate", | ||||||
| 	FSTransferChar:   "Filesystem Transfer", | 	FSTransferChar:   "Filesystem Transfer", | ||||||
| @@ -66,6 +68,7 @@ type Device struct { | |||||||
| 	motionValChar   *gatt.GattCharacteristic1 | 	motionValChar   *gatt.GattCharacteristic1 | ||||||
| 	fwVersionChar   *gatt.GattCharacteristic1 | 	fwVersionChar   *gatt.GattCharacteristic1 | ||||||
| 	currentTimeChar *gatt.GattCharacteristic1 | 	currentTimeChar *gatt.GattCharacteristic1 | ||||||
|  | 	localTimeChar   *gatt.GattCharacteristic1 | ||||||
| 	battLevelChar   *gatt.GattCharacteristic1 | 	battLevelChar   *gatt.GattCharacteristic1 | ||||||
| 	heartRateChar   *gatt.GattCharacteristic1 | 	heartRateChar   *gatt.GattCharacteristic1 | ||||||
| 	fsVersionChar   *gatt.GattCharacteristic1 | 	fsVersionChar   *gatt.GattCharacteristic1 | ||||||
| @@ -421,6 +424,8 @@ func (i *Device) resolveChars() error { | |||||||
| 			i.fwVersionChar = char | 			i.fwVersionChar = char | ||||||
| 		case CurrentTimeChar: | 		case CurrentTimeChar: | ||||||
| 			i.currentTimeChar = char | 			i.currentTimeChar = char | ||||||
|  | 		case LocalTimeChar: | ||||||
|  | 			i.localTimeChar = char | ||||||
| 		case BatteryLvlChar: | 		case BatteryLvlChar: | ||||||
| 			i.battLevelChar = char | 			i.battLevelChar = char | ||||||
| 		case HeartRateChar: | 		case HeartRateChar: | ||||||
| @@ -708,7 +713,9 @@ func (i *Device) WatchMotion(ctx context.Context) (<-chan MotionValues, error) { | |||||||
| 	return out, nil | 	return out, nil | ||||||
| } | } | ||||||
|  |  | ||||||
| // SetTime sets the watch's time using the Current Time Service | // SetTime sets the watch's | ||||||
|  | // * time using the Current Time Service's current time characteristic | ||||||
|  | // * timezone information using the CTS's local time characteristic | ||||||
| func (i *Device) SetTime(t time.Time) error { | func (i *Device) SetTime(t time.Time) error { | ||||||
| 	if err := i.checkStatus(i.currentTimeChar, CurrentTimeChar); err != nil { | 	if err := i.checkStatus(i.currentTimeChar, CurrentTimeChar); err != nil { | ||||||
| 		return err | 		return err | ||||||
| @@ -723,7 +730,38 @@ func (i *Device) SetTime(t time.Time) error { | |||||||
| 	binary.Write(buf, binary.LittleEndian, uint8(t.Weekday())) | 	binary.Write(buf, binary.LittleEndian, uint8(t.Weekday())) | ||||||
| 	binary.Write(buf, binary.LittleEndian, uint8((t.Nanosecond()/1000)/1e6*256)) | 	binary.Write(buf, binary.LittleEndian, uint8((t.Nanosecond()/1000)/1e6*256)) | ||||||
| 	binary.Write(buf, binary.LittleEndian, uint8(0b0001)) | 	binary.Write(buf, binary.LittleEndian, uint8(0b0001)) | ||||||
| 	return i.currentTimeChar.WriteValue(buf.Bytes(), nil) | 	if err := i.currentTimeChar.WriteValue(buf.Bytes(), nil); err != nil { | ||||||
|  | 		return err | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	if err := i.checkStatus(i.localTimeChar, LocalTimeChar); err != nil { | ||||||
|  | 		// If the characteristic is unavailable, | ||||||
|  | 		// fail silently, as many people may be on | ||||||
|  | 		// older InfiniTime versions. A warning | ||||||
|  | 		// may be added later. | ||||||
|  | 		if _, ok := err.(ErrCharNotAvail); ok { | ||||||
|  | 			return nil | ||||||
|  | 		} else { | ||||||
|  | 			return err | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 	_, offset := t.Zone() | ||||||
|  | 	dst := 0 | ||||||
|  |  | ||||||
|  | 	// Local time expects two values: the timezone offset and the dst offset, both | ||||||
|  | 	// expressed in quarters of an hour. | ||||||
|  | 	// Timezone offset is to be constant over DST, with dst offset holding the offset != 0 | ||||||
|  | 	// when DST is in effect. | ||||||
|  | 	// As there is no standard way in go to get the actual dst offset, we assume it to be 1h | ||||||
|  | 	// when DST is in effect | ||||||
|  | 	if t.IsDST() { | ||||||
|  | 		dst = 3600 | ||||||
|  | 		offset -= 3600 | ||||||
|  | 	} | ||||||
|  | 	bufTz := &bytes.Buffer{} | ||||||
|  | 	binary.Write(bufTz, binary.LittleEndian, uint8(offset / 3600 * 4)) | ||||||
|  | 	binary.Write(bufTz, binary.LittleEndian, uint8(dst / 3600 * 4)) | ||||||
|  | 	return i.localTimeChar.WriteValue(bufTz.Bytes(), nil) | ||||||
| } | } | ||||||
|  |  | ||||||
| // Notify sends a notification to InfiniTime via | // Notify sends a notification to InfiniTime via | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user