add update method #5
			
				
			
		
		
		
	| 
						 | 
				
			
			@ -37,10 +37,7 @@ func (s Service) Create(payload CreateOptions) error {
 | 
			
		|||
	}
 | 
			
		||||
 | 
			
		||||
	// New device data from payload
 | 
			
		||||
	deviceData, err := payload.newDevice()
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return err
 | 
			
		||||
	}
 | 
			
		||||
	deviceData := payload.newDevice()
 | 
			
		||||
 | 
			
		||||
	// Find deviceID existed or not
 | 
			
		||||
	if s.isDeviceIDExisted(ctx, deviceData.DeviceID) {
 | 
			
		||||
| 
						 | 
				
			
			@ -60,13 +57,17 @@ func (s Service) Create(payload CreateOptions) error {
 | 
			
		|||
	return nil
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (payload CreateOptions) newDevice() (result Device, err error) {
 | 
			
		||||
func (payload CreateOptions) newDevice() Device {
 | 
			
		||||
	timeNow := now()
 | 
			
		||||
	device := Device{
 | 
			
		||||
 | 
			
		||||
	// Get userAgent data
 | 
			
		||||
	osName, osVersion, isMobile := getUserAgentData(payload.UserAgent)
 | 
			
		||||
 | 
			
		||||
	return Device{
 | 
			
		||||
		ID:              mongodb.NewObjectID(),
 | 
			
		||||
		DeviceID:        payload.DeviceID,
 | 
			
		||||
		OSName:          getOSName(payload.UserAgent),
 | 
			
		||||
		OSVersion:       getOSVersion(payload.UserAgent),
 | 
			
		||||
		OSName:          osName,
 | 
			
		||||
		OSVersion:       osVersion,
 | 
			
		||||
		IP:              payload.IP,
 | 
			
		||||
		Language:        getLanguage(payload.Language),
 | 
			
		||||
		AuthToken:       payload.AuthToken,
 | 
			
		||||
| 
						 | 
				
			
			@ -76,14 +77,7 @@ func (payload CreateOptions) newDevice() (result Device, err error) {
 | 
			
		|||
		Model:           payload.Model,
 | 
			
		||||
		Manufacturer:    payload.Manufacturer,
 | 
			
		||||
		UserID:          payload.UserID,
 | 
			
		||||
		IsMobile:        isMobile,
 | 
			
		||||
		AppVersion:      payload.AppVersion,
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// App version
 | 
			
		||||
	if payload.AppVersion != "" {
 | 
			
		||||
		device.AppVersion = payload.AppVersion
 | 
			
		||||
		device.IsMobile = true
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	result = device
 | 
			
		||||
	return
 | 
			
		||||
}
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -36,11 +36,14 @@ func (s Service) UpdateByDeviceID(deviceID string, payload UpdateOptions) error
 | 
			
		|||
| 
					
 | 
			||||
		return err
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// Get userAgent data
 | 
			
		||||
| 
					
 cái này phải lấy từ userAgent chớ sao so sánh như vậy được cái này phải lấy từ userAgent chớ sao so sánh như vậy được 
			
		mấy cái này nên viết 1 func trả về  
			
			mấy cái này nên viết 1 func trả về `name, version, isMobile` rồi dùng thôi
```go
osName, osVersion, isMobile := getUserAgentData(ua)
``` 
			
		done done 
			
		done done 
			
		 | 
			||||
	osName, osVersion, isMobile := getUserAgentData(payload.UserAgent)
 | 
			
		||||
| 
					
 cái này phải lấy từ userAgent chớ sao so sánh như vậy được cái này phải lấy từ userAgent chớ sao so sánh như vậy được 
			
		mấy cái này nên viết 1 func trả về  
			
			mấy cái này nên viết 1 func trả về `name, version, isMobile` rồi dùng thôi
```go
osName, osVersion, isMobile := getUserAgentData(ua)
``` 
			
		done done 
			
		done done 
			
		 | 
			||||
 | 
			
		||||
| 
					
 cái này phải lấy từ userAgent chớ sao so sánh như vậy được cái này phải lấy từ userAgent chớ sao so sánh như vậy được 
			
		mấy cái này nên viết 1 func trả về  
			
			mấy cái này nên viết 1 func trả về `name, version, isMobile` rồi dùng thôi
```go
osName, osVersion, isMobile := getUserAgentData(ua)
``` 
			
		done done 
			
		done done 
			
		 | 
			||||
	// Setup update data
 | 
			
		||||
	updateData := bson.M{
 | 
			
		||||
		"$set": bson.M{
 | 
			
		||||
			"osName":          getOSName(payload.UserAgent),
 | 
			
		||||
| 
					
 cái này phải lấy từ userAgent chớ sao so sánh như vậy được cái này phải lấy từ userAgent chớ sao so sánh như vậy được 
			
		mấy cái này nên viết 1 func trả về  
			
			mấy cái này nên viết 1 func trả về `name, version, isMobile` rồi dùng thôi
```go
osName, osVersion, isMobile := getUserAgentData(ua)
``` 
			
		done done 
			
		done done 
			
		 | 
			||||
			"osVersion":       getOSVersion(payload.UserAgent),
 | 
			
		||||
| 
					
 cái này phải lấy từ userAgent chớ sao so sánh như vậy được cái này phải lấy từ userAgent chớ sao so sánh như vậy được 
			
		mấy cái này nên viết 1 func trả về  
			
			mấy cái này nên viết 1 func trả về `name, version, isMobile` rồi dùng thôi
```go
osName, osVersion, isMobile := getUserAgentData(ua)
``` 
			
		done done 
			
		done done 
			
		 | 
			||||
			"osName":          osName,
 | 
			
		||||
| 
					
 cái này phải lấy từ userAgent chớ sao so sánh như vậy được cái này phải lấy từ userAgent chớ sao so sánh như vậy được 
			
		mấy cái này nên viết 1 func trả về  
			
			mấy cái này nên viết 1 func trả về `name, version, isMobile` rồi dùng thôi
```go
osName, osVersion, isMobile := getUserAgentData(ua)
``` 
			
		done done 
			
		done done 
			
		 | 
			||||
			"osVersion":       osVersion,
 | 
			
		||||
| 
					
 cái này phải lấy từ userAgent chớ sao so sánh như vậy được cái này phải lấy từ userAgent chớ sao so sánh như vậy được 
			
		mấy cái này nên viết 1 func trả về  
			
			mấy cái này nên viết 1 func trả về `name, version, isMobile` rồi dùng thôi
```go
osName, osVersion, isMobile := getUserAgentData(ua)
``` 
			
		done done 
			
		done done 
			
		 | 
			||||
			"ip":              payload.IP,
 | 
			
		||||
			"language":        getLanguage(payload.Language),
 | 
			
		||||
			"authToken":       payload.AuthToken,
 | 
			
		||||
| 
						 | 
				
			
			@ -48,7 +51,7 @@ func (s Service) UpdateByDeviceID(deviceID string, payload UpdateOptions) error
 | 
			
		|||
| 
					
 cái này phải lấy từ userAgent chớ sao so sánh như vậy được cái này phải lấy từ userAgent chớ sao so sánh như vậy được 
			
		cái này phải lấy từ userAgent chớ sao so sánh như vậy được cái này phải lấy từ userAgent chớ sao so sánh như vậy được 
			
		mấy cái này nên viết 1 func trả về  
			
			mấy cái này nên viết 1 func trả về `name, version, isMobile` rồi dùng thôi
```go
osName, osVersion, isMobile := getUserAgentData(ua)
``` 
			
		mấy cái này nên viết 1 func trả về  
			
			mấy cái này nên viết 1 func trả về `name, version, isMobile` rồi dùng thôi
```go
osName, osVersion, isMobile := getUserAgentData(ua)
``` 
			
		done done 
			
		done done 
			
		done done 
			
		done done 
			
		 | 
			||||
			"model":           payload.Model,
 | 
			
		||||
			"manufacturer":    payload.Manufacturer,
 | 
			
		||||
			"appVersion":      payload.AppVersion,
 | 
			
		||||
			"isMobile":        payload.AppVersion != "",
 | 
			
		||||
| 
					
 cái này phải lấy từ userAgent chớ sao so sánh như vậy được cái này phải lấy từ userAgent chớ sao so sánh như vậy được 
			
		mấy cái này nên viết 1 func trả về  
			
			mấy cái này nên viết 1 func trả về `name, version, isMobile` rồi dùng thôi
```go
osName, osVersion, isMobile := getUserAgentData(ua)
``` 
			
		done done 
			
		done done 
			
		 | 
			||||
			"isMobile":        isMobile,
 | 
			
		||||
| 
					
 cái này phải lấy từ userAgent chớ sao so sánh như vậy được cái này phải lấy từ userAgent chớ sao so sánh như vậy được 
			
		mấy cái này nên viết 1 func trả về  
			
			mấy cái này nên viết 1 func trả về `name, version, isMobile` rồi dùng thôi
```go
osName, osVersion, isMobile := getUserAgentData(ua)
``` 
			
		done done 
			
		done done 
			
		 | 
			||||
			"lastActivatedAt": now(),
 | 
			
		||||
		},
 | 
			
		||||
	}
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
					
 cái này phải lấy từ userAgent chớ sao so sánh như vậy được cái này phải lấy từ userAgent chớ sao so sánh như vậy được 
			
		cái này phải lấy từ userAgent chớ sao so sánh như vậy được cái này phải lấy từ userAgent chớ sao so sánh như vậy được 
			
		mấy cái này nên viết 1 func trả về  
			
			mấy cái này nên viết 1 func trả về `name, version, isMobile` rồi dùng thôi
```go
osName, osVersion, isMobile := getUserAgentData(ua)
``` 
			
		mấy cái này nên viết 1 func trả về  
			
			mấy cái này nên viết 1 func trả về `name, version, isMobile` rồi dùng thôi
```go
osName, osVersion, isMobile := getUserAgentData(ua)
``` 
			
		done done 
			
		done done 
			
		done done 
			
		done done 
			
		 | 
			||||
| 
						 | 
				
			
			@ -31,14 +31,9 @@ func (s Service) isDeviceIDExisted(ctx context.Context, deviceID string) bool {
 | 
			
		|||
	return !device.ID.IsZero()
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func getOSName(userAgent string) string {
 | 
			
		||||
func getUserAgentData(userAgent string) (string, string, bool) {
 | 
			
		||||
	uaData := ua.New(userAgent)
 | 
			
		||||
	return uaData.OSInfo().Name
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func getOSVersion(userAgent string) string {
 | 
			
		||||
	uaData := ua.New(userAgent)
 | 
			
		||||
	return uaData.OSInfo().Version
 | 
			
		||||
	return uaData.OSInfo().Name, uaData.OSInfo().Version, uaData.Mobile()
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func getLanguage(lang string) string {
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
cái này phải lấy từ userAgent chớ sao so sánh như vậy được
cái này phải lấy từ userAgent chớ sao so sánh như vậy được
mấy cái này nên viết 1 func trả về
name, version, isMobilerồi dùng thôimấy cái này nên viết 1 func trả về
name, version, isMobilerồi dùng thôidone
done
done
done