1
0
mirror of https://github.com/MontFerret/ferret.git synced 2025-01-18 03:22:02 +02:00
ferret/pkg/stdlib/html/navigate.go

54 lines
1.2 KiB
Go
Raw Normal View History

package html
import (
"context"
"github.com/MontFerret/ferret/pkg/drivers"
"github.com/MontFerret/ferret/pkg/runtime/core"
"github.com/MontFerret/ferret/pkg/runtime/values"
"github.com/MontFerret/ferret/pkg/runtime/values/types"
)
// Navigate navigates a given page to a new resource.
2018-10-14 19:06:27 +02:00
// The operation blocks the execution until the page gets loaded.
// Which means there is no need in WAIT_NAVIGATION function.
// @param page (HTMLPage) - Target page.
2018-10-14 19:06:27 +02:00
// @param url (String) - Target url to navigate.
// @param timeout (Int, optional) - Optional timeout. Default is 5000.
func Navigate(ctx context.Context, args ...core.Value) (core.Value, error) {
2018-10-08 02:15:41 +02:00
err := core.ValidateArgs(args, 2, 3)
if err != nil {
return values.None, err
}
page, err := drivers.ToPage(args[0])
if err != nil {
return values.None, err
}
err = core.ValidateType(args[1], types.String)
if err != nil {
return values.None, err
}
2018-10-08 02:15:41 +02:00
timeout := values.NewInt(defaultTimeout)
if len(args) > 2 {
err = core.ValidateType(args[2], types.Int)
2018-10-08 02:15:41 +02:00
if err != nil {
return values.None, err
}
timeout = args[2].(values.Int)
}
ctx, fn := waitTimeout(ctx, timeout)
defer fn()
return values.None, page.Navigate(ctx, args[1].(values.String))
}