browscap-go

command module
v0.1.0 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Sep 22, 2024 License: MIT Imports: 10 Imported by: 0

README

Browser Capabilities GoLang Project

This is a Go version of a library that matches user agents against the Browscap database. It uses a radix tree and backtracking to find the most specific pattern for a given user agent. The search index is completely stored in memory. Once initialized, the full Browscap database requires about 20MB of RAM; however, during initialization, it may require up to 200MB of RAM.

For browser data, it requires an external storage, which is currently implemented using SQLite, MySQL, or PostgreSQL.

Installation

go get github.com/eugeniypetrov/browscap-go

Usage

To build the cache, you need to download the PHP version of the database from Browscap and run the following code:

db, err := sqlx.Open("sqlite3", "browscap.sqlite")
if err != nil {
    panic(err)
}

storage := browscap.NewSqliteBrowserStorage(db)
err := browscap.NewLoader(storage).Compile("full_php_browscap.ini")
if err != nil {
    panic(err)
}

It will take some time to parse the file and build the cache. Alternatively, you can install the CLI tool using the following command:

go install github.com/eugeniypetrov/browscap-go@latest

and then run the following command:

browscap-go compile \
  -srorage=sqlite \
  -dsn=browscap.sqlite \
  -filename=full_php_browscap.ini

This will create an SQLite database with all the data from the full_php_browscap.ini file. After that, you can use the following code to match user agents:

bc, err := browscap.NewLoader(storage).Load()
if err != nil {
    panic(err)
}

browser, _ := bc.GetBrowser(userAgent)

Documentation

The Go Gopher

There is no documentation for this package.

Directories

Path Synopsis

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL