package mechaml
Install
    
    dune-project
 Dependency
Authors
Maintainers
Sources
sha256=dcf23595edacbcec1946affb3817b791f3edc176bd4bad2f6b5d74965043d6bd
    
    
  sha512=a0c2ed7dee79a44bb4ee5eb82500754b6cc0a3ca1ac40b3a66217e868d889ba9ecce9df85ce7ce95d958372ac8aedb5fd5523c0e3b6c15adcdc43f241f0ec5db
    
    
  Description
Mechaml is a functional web scraping library that allows to :
- Fetch web content
- Analyze, fill and submit HTML forms
- Handle cookies, headers and redirections
README
Mechaml 
Description
Mechaml is a functional web scraping library that allows to :
- Fetch web content
- Analyze, fill and submit HTML forms
- Handle cookies, headers and redirections
Mechaml is built on top of existing libraries that provide low-level features : Cohttp and Lwt for asynchronous I/O and HTTP handling, and Lambdasoup to parse HTML. It provides an interface that handles the interactions between these and add a few other features.
Overview
The library is divided into 3 main modules :
- Agent : User-agent features. Perform requests, get back content, headers, status code, ...
- Cookiejar : Cookies handling
- Page : HTML parsing and forms handling
The Format module provides helpers to manage the formatted content in forms such as date, colors, etc. For more details, see the documentation
Installation
From opam
opam install mechamlFrom source
Mechaml uses the dune build system, which can be installed through opam. Then, just run
dune buildto build the library.
Use dune build @doc to generate the documentation, dune runtest to build and execute tests, and dune build examples/XXX.exe to compile example XXX.
Usage
Here is sample of code that fetches a web page, fills a login form and submits it in the monadic style:
open Mechaml
module M = Agent.Monad
open M.Infix
let require msg = function
  | Some a -> a
  | None -> failwith msg
let action_login =
  Agent.get "http://www.somewebsite.com"
  >|= Agent.HttpResponse.page
  >|= (function page ->
    page
    |> Page.form_with "[name=login]"
    |> require "Can't find the login form !"
    |> Page.Form.set "username" "mynick"
    |> Page.Form.set "password" "@xlz43")
  >>= Agent.submit
let _ =
  M.run (Agent.init ()) action_loginMore examples are available in the dedicated folder.
license
GNU LGPL v3
Dependencies (9)
- 
  
    ocaml
  
  
    >= "4.03.0"
- 
  
    lambdasoup
  
  
    < "0.7.0"
- uri
- lwt
- cohttp-lwt-unix
- cohttp-lwt
- 
  
    cohttp
  
  
    >= "0.21.0" & < "3.0.0"
- 
  
    ocaml-syntax-shims
  
  
    build
- 
  
    dune
  
  
    >= "1.8.0"
Dev Dependencies (1)
- 
  
    alcotest
  
  
    with-test & >= "0.8.0" & < "1.4.0"
Used by
None
Conflicts
None