#!/usr/bin/env python ''' This Source Code Form is copyright of 51Degrees Mobile Experts Limited. Copyright 2017 51Degrees Mobile Experts Limited, 5 Charlotte Close, Caversham, Reading, Berkshire, United Kingdom RG4 7BY This Source Code Form is the subject of the following patents and patent applications, owned by 51Degrees Mobile Experts Limited of 5 Charlotte Close, Caversham, Reading, Berkshire, United Kingdom RG4 7BY: European Patent No. 2871816; European Patent Application No. 17184134.9; United States Patent Nos. 9,332,086 and 9,350,823; and United States Patent Application No. 15/686,066. This Source Code Form is subject to the terms of the Mozilla Public License, v. 2.0. If a copy of the MPL was not distributed with this file, You can obtain one at http://mozilla.org/MPL/2.0/. This Source Code Form is "Incompatible With Secondary Licenses", as defined by the Mozilla Public License, v. 2.0. ''' ''' Getting started example of using 51Degrees device detection match metrics information. The example shows how to:
  1. Import settings from the 51Degrees settings file

    dataFile = settings.V3_WRAPPER_DATABASE
    properties = settings.PROPERTIES
    cacheSize = settings.CACHE_SIZE
    poolSize = settings.POOL_SIZE
    

  2. Instantiate the 51Degrees device detection provider with these properties

    provider = fiftyone_degrees_mobile_detector_v3_wrapper.Provider(dataFile,
    	properties,
    	cacheSize,
    	poolSize)
    

  3. Produce a match for a single HTTP User-Agent header

    match = provider.getMatch(userAgent)
    

  4. Obtain device Id: consists of four components separated by a hyphen symbol: Hardware-Platform-Browser-IsCrawler where each Component represents an ID of the corresponding Profile.

    match.getDeviceId()
  5. Obtain match method: provides information about the algorithm that was used to perform detection for a particular User-Agent. For more information on what each method means please see: How device detection works

    match.getMethod()
  6. Obtain difference: used when detection method is not Exact or None. This is an integer value and the larger the value the less confident the detector is in this result.

    match.getDifference()
  7. Obtain signature rank: an integer value that indicates how popular the device is. The lower the rank the more popular the signature.

    match.getRank()
This example can be run in any directory, but assumes your settings file contains a valid dataFile location and has the IsMobile property selected.
''' # // Snippet Start from FiftyOneDegrees import fiftyone_degrees_mobile_detector_v3_wrapper from fiftyone_degrees.mobile_detector.conf import settings import sys ''' Imports settings from the settings file. The Default settings file, and details on how to change it can be output by running the command

51degrees-mobile-detector settings

''' dataFile = settings.V3_WRAPPER_DATABASE properties = settings.PROPERTIES cacheSize = settings.CACHE_SIZE poolSize = settings.POOL_SIZE ''' Initialises the device detection provider with settings from the settings file. By default this will use the included Lite data file For more info see: compare data options ''' provider = fiftyone_degrees_mobile_detector_v3_wrapper.Provider(dataFile, properties, cacheSize, poolSize) # User-Agent string of an iPhone mobile device. mobileUserAgent = ("Mozilla/5.0 (iPhone; CPU iPhone OS 7_1 like Mac OS X) " "AppleWebKit/537.51.2 (KHTML, like Gecko) 'Version/7.0 Mobile/11D167 " "Safari/9537.53") # User-Agent string of Firefox Web browser version 41 on desktop. desktopUserAgent = ("Mozilla/5.0 (Windows NT 6.3; WOW64; rv:41.0) " "Gecko/20100101 Firefox/41.0") # User-Agent string of a MediaHub device. mediaHubUserAgent = ("Mozilla/5.0 (Linux; Android 4.4.2; X7 Quad Core " "Build/KOT49H) AppleWebKit/537.36 (KHTML, like Gecko) Version/4.0 " "Chrome/30.0.0.0 Safari/537.36") ''' output_metrics function. Takes a match object as an argument and prints the match metrics relating to the specific match. ''' def output_metrics(match): sys.stdout.write(' Id: %s\n' % match.getDeviceId()) sys.stdout.write(' Match Method: %s\n' % match.getMethod()) sys.stdout.write(' Difference: %s\n' % match.getDifference()) sys.stdout.write(' Rank: %s\n' % match.getRank()) def main(): sys.stdout.write('Starting Getting Started Match Metrics Example.\n') # Carries out a match with a mobile User-Agent. sys.stdout.write('Mobile User-Agent: %s\n' % mobileUserAgent) match = provider.getMatch(mobileUserAgent) output_metrics(match) # Carries out a match with a desktop User-Agent. sys.stdout.write('Desktop User-Agent: %s\n' % desktopUserAgent) match = provider.getMatch(desktopUserAgent) output_metrics(match) # Carries out a match with a MediaHub User-Agent. sys.stdout.write('Media Hub User-Agent: %s\n' % mediaHubUserAgent) match = provider.getMatch(mediaHubUserAgent) output_metrics(match) if __name__ == '__main__': main() # // Snippet End