#!/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 trie device detection. The example shows how to:
  1. Import settings from the 51Degrees settings file

    dataFile = settings.V3_WRAPPER_TRIE_DATABASE
    properties = settings.PROPERTIES
    

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

    provider = fiftyone_degrees_mobile_detector_v3_trie_wrapper.Provider(
    	dataFile,
    	properties)
    

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

    match = provider.getMatch(userAgent)
    

  4. Extract the value of the IsMobile property

    match.getValues('IsMobile')
    

This example can be run in any directory, but assumes your settings file contains a valid dataFile location and has the IsMobile property selected. By comparing this to the gettingstarted.py example which uses the pattern method, you can see the differences are the module name, the data file, and it does not use a cache or pool, so these do not need to be set.
''' # // Snippet Start from FiftyOneDegrees import fiftyone_degrees_mobile_detector_v3_trie_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_TRIE_WRAPPER_DATABASE properties = settings.PROPERTIES ''' 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_trie_wrapper.Provider( dataFile, properties) # 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") def main(): sys.stdout.write('Starting Getting Started Trie Example.\n') # Carries out a match with a mobile User-Agent. sys.stdout.write('\nMobile User-Agent: %s\n' % mobileUserAgent) match = provider.getMatch(mobileUserAgent) sys.stdout.write(' IsMobile: %s\n' % match.getValues('IsMobile')) # Carries out a match with a desktop User-Agent. sys.stdout.write('\nDesktop User-Agent: %s\n' % desktopUserAgent) match = provider.getMatch(desktopUserAgent) sys.stdout.write(' IsMobile: %s\n' % match.getValues('IsMobile')) # Carries out a match with a MediaHub User-Agent. sys.stdout.write('\nMedia Hub User-Agent: %s\n' % mediaHubUserAgent) match = provider.getMatch(mediaHubUserAgent) sys.stdout.write(' IsMobile: %s\n' % match.getValues('IsMobile')) if __name__ == '__main__': main() # // Snippet End