An open API service indexing awesome lists of open source software.

https://github.com/sourcegraph/webloop

WebLoop: Scriptable, headless WebKit with a Go API. Like PhantomJS, but for Go.
https://github.com/sourcegraph/webloop

Last synced: 8 months ago
JSON representation

WebLoop: Scriptable, headless WebKit with a Go API. Like PhantomJS, but for Go.

Awesome Lists containing this project

README

          

# WebLoop

Scriptable, headless WebKit with a Go API. Like [PhantomJS](http://phantomjs.org/), but for Go. Render static HTML versions of dynamic JavaScript applications, automate browsing, run arbitrary JavaScript in a browser window context, etc., all from Go or the command line.

* [Documentation on Sourcegraph](https://sourcegraph.com/github.com/sourcegraph/webloop)

## Requirements

* [Go](http://golang.org) >= 1.2rc1 (due to [#3250](https://code.google.com/p/go/issues/detail?id=3250))
* [WebKitGTK+](http://webkitgtk.org/) >= 2.0.0
* [go-webkit2](https://sourcegraph.com/github.com/sourcegraph/go-webkit2)

For instructions on installing these dependencies, see the [go-webkit2
README](https://sourcegraph.com/github.com/sourcegraph/go-webkit2@master/-/blob/README.md).

To install WebLoop, run: `go get github.com/sourcegraph/webloop/...`

## Usage

### Static HTML rendering reverse proxy

The included command `static-reverse-proxy` proxies a dynamic JavaScript application and serves an equivalent statically rendered HTML website to clients. Run it with:

```
$ go install github.com/sourcegraph/webloop/...
$ static-reverse-proxy
```

For example, to proxy a dynamic application at http://example.com and serve an
equivalent statically rendered HTML website on http://localhost:13000, run:

```
$ static-reverse-proxy -target=http://example.com -http=:13000
```

Run with `-h` to see more information.

### Rendering static HTML from a dynamic, single-page [AngularJS](http://angularjs.org) app

`StaticRenderer` is an HTTP handler that serves a static HTML version of a
dynamic web application. Use it like:

```go
staticHandler := &webloop.StaticRenderer{
TargetBaseURL: "http://dynamic-app.example.com",
WaitTimeout: time.Second * 3,
ReturnUnfinishedPages: true
}
http.Handle("/", staticHandler)
```

See the `examples/angular-static-seo/` directory for example code. Run the included binary with:

```
$ go run examples/angular-static-seo/server.go
```

Instructions will be printed for accessing the 2 local demo HTTP servers. Run
with `-h` to see more information.

### Operating a headless WebKit and running arbitrary JavaScript in the page

```go
package webloop_test

import (
"fmt"
"os"
"runtime"

"github.com/gotk3/gotk3/gtk"
"github.com/sourcegraph/webloop"
)

func Example() {
gtk.Init(nil)
go func() {
runtime.LockOSThread()
gtk.Main()
}()

ctx := webloop.New()
view := ctx.NewView()
defer view.Close()
view.Open("http://google.com")
err := view.Wait()
if err != nil {
fmt.Fprintf(os.Stderr, "Failed to load URL: %s", err)
os.Exit(1)
}
res, err := view.EvaluateJavaScript("document.title")
if err != nil {
fmt.Fprintf(os.Stderr, "Failed to run JavaScript: %s", err)
os.Exit(1)
}
fmt.Printf("JavaScript returned: %q\n", res)
// output:
// JavaScript returned: "Google"
}
```

See `webloop_test.go` for more examples.

## TODO

* [Set up CI testing.](https://github.com/sourcegraph/webloop/issues/1) This
is difficult because all of the popular CI services run older versions of
Ubuntu that make it difficult to install WebKitGTK+ >= 2.0.0.
* Add the ability for JavaScript code to send messages to WebLoop, similar to
[PhantomJS's callPhantom]
(https://github.com/ariya/phantomjs/wiki/API-Reference-WebPage#oncallback)
mechanism.

## Users

* WebLoop is used to render static HTML pages on [Sourcegraph](https://sourcegraph.com) for search engine crawlers

## Contributors

See the AUTHORS file for a list of contributors.

Submit contributions via GitHub pull request. Patches should include tests and
should pass [golint](https://github.com/golang/lint).