All Downloads are FREE. Search and download functionalities are using the official Maven repository.

fiftyone.device.example.illustration.GettingStarted Maven / Gradle / Ivy

There is a newer version: 3.2.18.1
Show newest version
/*
 * 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.
 */

package fiftyone.device.example.illustration;

import fiftyone.device.example.Shared;
import fiftyone.mobile.detection.Match;
import fiftyone.mobile.detection.Provider;
import fiftyone.mobile.detection.factories.StreamFactory;

import java.io.Closeable;
import java.io.IOException;

/**
 * 
 * Getting started example of using 51Degrees device detection. The example 
 * shows how to:
 * 
    *
  1. Instantiate 51Degrees detection provider *
     *  
     *      provider = new Provider(StreamFactory.create(
     *      Shared.getLitePatternV32(), false));
     *  
     *  
    *
  2. Pass in a single HTTP User-Agent header *
     *  
     *      Match match = provider.match(userAgent);
     *  
     *  
    *
  3. Extract the value of the IsMobile Property *
     *  
     *      match.getValues("IsMobile").toString();
     *  
     *  
    *
* * main assumes it is being run with a working directory at root of * project or of this module. */ public class GettingStarted implements Closeable { // Snippet Start // Device detection provider which takes User-Agents and returns matches. protected final Provider provider; // User-Agent string of a iPhone mobile device. protected final String 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 of version 41 used on desktop. protected final String desktopUserAgent = "Mozilla/5.0 (Windows NT 6.3; " + "WOW64; rv:41.0) Gecko/20100101 Firefox/41.0"; // User-Agent string of a MediaHub device. protected final String 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"; /** * Initialises the device detection Provider with the included Lite data * file. For more data see: * compare data options * * * @throws IOException can be thrown if there is a problem reading from the * provided data file. */ public GettingStarted() throws IOException { provider = new Provider(StreamFactory.create( Shared.getLitePatternV32(), false)); } /** * Matches provided User-Agent string and returns IsMobile property value. * Detection initiated by invoking {@link Provider#match(java.lang.String)}. * Detection results are then stored in the {@link Match} object and can be * accessed using the {@code Match.getValues("PropertyName")} method. * * @param userAgent HTTP User-Agent string. * @return String with value for IsMobile property for a given User-Agent. * @throws IOException if there is a problem accessing the data file. */ public String detect(String userAgent) throws IOException { Match match = provider.match(userAgent); return match.getValues("IsMobile").toString(); } /** * Main entry point for this example. For each of the User-Agents defined * in this class: *
    *
  1. invokes {@link #detect(java.lang.String)} method; and *
  2. prints results. *
* * Result in this case will be either True or False, depending on whether * the User-Agent belongs to a mobile device or a non-mobile device. * * @param args command line arguments, not used. * @throws java.io.IOException if there is a problem accessing the data file * that will be used for device detection. */ public static void main(String[] args) throws IOException { System.out.println("Starting GettingStarted example."); GettingStarted gs = new GettingStarted(); try { System.out.println("Mobile User-Agent: " + gs.mobileUserAgent); System.out.println("IsMobile: " + gs.detect(gs.mobileUserAgent)); System.out.println("Desktop User-Agent: " + gs.desktopUserAgent); System.out.println("IsMobile: " + gs.detect(gs.desktopUserAgent)); System.out.println("MediaHub User-Agent: " + gs.mediaHubUserAgent); System.out.println("IsMobile: " + gs.detect(gs.mediaHubUserAgent)); } finally { gs.close(); } } /** * Closes the {@link fiftyone.mobile.detection.Dataset} by releasing data * file readers and freeing the data file from locks. This method should * only be used when the {@code Dataset} is no longer required, i.e. when * device detection functionality is no longer required, or the data file * needs to be freed. * * @throws IOException if there is a problem accessing the data file. */ @Override public void close() throws IOException { provider.dataSet.close(); } // Snippet End }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy