Documentation ¶
Overview ¶
Package chromedpundetected provides a chromedp context with an undetected Chrome browser.
Package chromedpundetected provides a chromedp context with an undetected Chrome browser.
Index ¶
- Constants
- Variables
- func BlockURLs(url ...string) chromedp.ActionFunc
- func LoadCookies(cookies []Cookie) chromedp.ActionFunc
- func LoadCookiesFromFile(path string) chromedp.ActionFunc
- func MoveMouseToPosition(x, y float64, setters ...MoveOptionSetter) chromedp.ActionFunc
- func NetworkIdleListener(ctx context.Context, networkIdleTimeout, totalTimeout time.Duration) chan IdleEvent
- func NetworkIdlePermanentListener(ctx context.Context, networkIdleTimeout time.Duration) (chan IdleEvent, func())
- func New(config Config) (context.Context, context.CancelFunc, error)
- func RunCommand(method string, params any) chromedp.ActionFunc
- func RunCommandWithRes(method string, params, res any) chromedp.ActionFunc
- func SaveCookies(cookies *[]Cookie) chromedp.ActionFunc
- func SaveCookiesTo(path string) chromedp.ActionFunc
- func SendKeys(sel any, v string, opts ...chromedp.QueryOption) chromedp.ActionFunc
- func UserAgentOverride(userAgent string) chromedp.ActionFunc
- type Config
- type Cookie
- type IdleEvent
- type MouseMoveOptions
- type MoveOptionSetter
- type Option
- func WithChromeBinary(path string) Option
- func WithChromeFlags(opts ...chromedp.ExecAllocatorOption) Option
- func WithContext(ctx context.Context) Option
- func WithExtensions(extensions ...string) Option
- func WithHeadless() Option
- func WithLogLevel(level int) Option
- func WithNoSandbox(b bool) Option
- func WithPort(port int) Option
- func WithTimeout(timeout time.Duration) Option
- func WithUserDataDir(dir string) Option
Constants ¶
const ( // DefaultNoSandbox enables the 'no-sandbox' flag by default. DefaultNoSandbox = true )
Variables ¶
var (
DefaultUserDirPrefix = "chromedp-undetected-"
)
Defaults.
var (
ErrXvfbNotFound = errors.New("xvfb not found. Please install (Linux only)")
)
Errors.
Functions ¶
func BlockURLs ¶ added in v1.3.2
func BlockURLs(url ...string) chromedp.ActionFunc
BlockURLs blocks a set of URLs in Chrome.
func LoadCookies ¶ added in v1.3.2
func LoadCookies(cookies []Cookie) chromedp.ActionFunc
LoadCookies will load a set of cookies into the browser.
func LoadCookiesFromFile ¶ added in v1.3.2
func LoadCookiesFromFile(path string) chromedp.ActionFunc
LoadCookiesFromFile takes a file path to a json file containing cookies, and loads in the cookies into the browser.
func MoveMouseToPosition ¶ added in v1.3.6
func MoveMouseToPosition(x, y float64, setters ...MoveOptionSetter) chromedp.ActionFunc
MoveMouseToPosition moves the mouse to the given position, mimic random human mouse movements.
If desired you can tweak the mouse movement behavior, defaults are set to mimic human mouse movements.
func NetworkIdleListener ¶ added in v1.3.7
func NetworkIdleListener(ctx context.Context, networkIdleTimeout, totalTimeout time.Duration) chan IdleEvent
NetworkIdleListener sets up a listener to monitor for network idle events.
This can be used as a proxy to know for e.g. when a page has fully loaded, assuming that the page doesn't send any network requests within the networkIdleTimeout period after is has finished loading.
This function creates a listener that monitors the target specified by the given context for network activity. It triggers a "NETWORK IDLE" event if no network request is sent within the provided `networkIdleTimeout` duration after a network idle lifecycle event.
After the network is considered idle, the listener will terminate and the channel will close.
Parameters:
- ctx: The context for which the listener is set up. Usually, this context is tied to a specific browser tab or page.
- networkIdleTimeout: The duration to wait for no network activity after a network idle lifecycle event before considering the network to be truly idle.
- totalTimeout: The duration to wait for the network to be idle before terminating the listener.
Returns: 1. A channel of type IdleEvent. When the network is considered idle, an IdleEvent with IsIdle set to true is sent through this channel.
func NetworkIdlePermanentListener ¶ added in v1.3.7
func NetworkIdlePermanentListener(ctx context.Context, networkIdleTimeout time.Duration) (chan IdleEvent, func())
This can be used as a proxy to know for e.g. when a page has fully loaded, assuming that the page doesn't send any network requests within the networkIdleTimeout period after is has finished loading.
This function creates a listener that monitors the target specified by the given context for network activity. It triggers a "NETWORK IDLE" event if no network request is sent within the provided `networkIdleTimeout` duration after a network idle lifecycle event.
It's designed to run indefinitely, i.e., it doesn't automatically stop listening after an idle event or after a certain period. To manually stop listening and to free up associated resources, one should call the returned cancel function.
Parameters:
- ctx: The context for which the listener is set up. Usually, this context is tied to a specific browser tab or page.
- networkIdleTimeout: The duration to wait for no network activity after a network idle lifecycle event before considering the network to be truly idle.
Returns:
- A channel of type IdleEvent. When the network is considered idle, an IdleEvent with IsIdle set to true is sent through this channel.
- A cancel function. This function can be called to terminate the listener and close the channel.
func RunCommand ¶ added in v1.3.2
func RunCommand(method string, params any) chromedp.ActionFunc
RunCommand runs any Chrome Dev Tools command, with any params.
In contrast to the native method of chromedp, with this method you can directly pass in a map with the data passed to the command.
func RunCommandWithRes ¶ added in v1.3.2
func RunCommandWithRes(method string, params, res any) chromedp.ActionFunc
RunCommandWithRes runs any Chrome Dev Tools command, with any params and sets the result to the res parameter. Make sure it is a pointer.
In contrast to the native method of chromedp, with this method you can directly pass in a map with the data passed to the command.
func SaveCookies ¶ added in v1.3.3
func SaveCookies(cookies *[]Cookie) chromedp.ActionFunc
SaveCookies extracts the cookies from the current URL and appends them to provided array.
func SaveCookiesTo ¶ added in v1.3.3
func SaveCookiesTo(path string) chromedp.ActionFunc
SaveCookiesTo extracts the cookies from the current page and saves them as JSON to the provided path.
func SendKeys ¶ added in v1.3.4
func SendKeys(sel any, v string, opts ...chromedp.QueryOption) chromedp.ActionFunc
SendKeys does the same as chromedp.SendKeys excepts it randomly waits 100-500ms between sending key presses.
func UserAgentOverride ¶ added in v1.3.1
func UserAgentOverride(userAgent string) chromedp.ActionFunc
UserAgentOverride overwrites the Chrome user agent.
It's better to use this method than emulation.UserAgentOverride.
Types ¶
type Config ¶
type Config struct { // Ctx is the base context to use. By default a background context will be used. Ctx context.Context `json:"-" yaml:"-"` // ContextOptions are chromedp context option. ContextOptions []chromedp.ContextOption `json:"-" yaml:"-"` // ChromeFlags are additional Chrome flags to pass to the browser. // // NOTE: adding additional flags can make the detection unstable, so test, // and be careful of what flags you add. Mostly intended to configure things // like a proxy. Also check if the flags you want to set are not already set // by this library. ChromeFlags []chromedp.ExecAllocatorOption // UserDataDir is the path to the directory where Chrome user data is stored. // // By default a temporary directory will be used. UserDataDir string `json:"userDataDir" yaml:"userDataDir"` // LogLevel is the Chrome log level, 0 by default. LogLevel int `json:"logLevel" yaml:"logLevel"` // NoSandbox dictates whether the no-sanbox flag is added. Defaults to true. NoSandbox bool `json:"noSandbox" yaml:"noSandbox"` // ChromePath is a specific binary path for Chrome. // // By default the chrome or chromium on your PATH will be used. ChromePath string `json:"chromePath" yaml:"chromePath"` // Port is the Chrome debugger port. By default a random port will be used. Port int `json:"port" yaml:"port"` // Timeout is the context timeout. Timeout time.Duration `json:"timeout" yaml:"timeout"` // Headless dicates whether Chrome will start headless (without a visible window) // // It will NOT use the '--headless' option, rather it will use a virtual display. // Requires Xvfb to be installed, only available on Linux. Headless bool `json:"headless" yaml:"headless"` // Extensions are the paths to the extensions to load. Extensions []string `json:"extensions" yaml:"extensions"` // language to be used otherwise system/OS defaults are used // https://developer.chrome.com/docs/webstore/i18n/#localeTable Language string }
Config is a undetected Chrome config.
type Cookie ¶ added in v1.3.2
type Cookie struct { Name string `json:"name" yaml:"name"` Value string `json:"value" yaml:"value"` Domain string `json:"domain" yaml:"domain"` Path string `json:"path" yaml:"path"` Expires float64 `json:"expires" yaml:"expires"` HTTPOnly bool `json:"httpOnly" yaml:"httpOnly"` Secure bool `json:"secure" yaml:"secure"` }
Cookie is used to set browser cookies.
type IdleEvent ¶ added in v1.3.7
type IdleEvent struct {
IsIdle bool
}
IdleEvent is sent through the channel returned by NetworkIdleListener when the network is considered idle. This event can be used to determine when a page has finished loading.
type MouseMoveOptions ¶ added in v1.3.6
type MouseMoveOptions struct {
// contains filtered or unexported fields
}
MouseMoveOptions contains options for mouse movement.
type MoveOptionSetter ¶ added in v1.3.6
type MoveOptionSetter func(*MouseMoveOptions)
MoveOptionSetter defines a function type to set mouse move options.
func WithDelayRange ¶ added in v1.3.6
func WithDelayRange(min, max time.Duration) MoveOptionSetter
WithDelayRange returns a MoveOptionSetter that sets the delay range between steps.
func WithRandomJitter ¶ added in v1.3.6
func WithRandomJitter(jitter float64) MoveOptionSetter
WithRandomJitter returns a MoveOptionSetter that sets the random jitter to introduce in mouse movement.
func WithSteps ¶ added in v1.3.6
func WithSteps(s int) MoveOptionSetter
WithSteps returns a MoveOptionSetter that sets the number of steps for the mouse movement.
func WithVisualizeMouse ¶ added in v1.3.6
func WithVisualizeMouse() MoveOptionSetter
WithVisualizeMouse returns a MoveOptionSetter that enables mouse movement visualization.
type Option ¶
type Option func(*Config)
Option is a functional option.
func WithChromeBinary ¶
WithChromeBinary sets the chrome binary path.
func WithChromeFlags ¶ added in v0.1.2
func WithChromeFlags(opts ...chromedp.ExecAllocatorOption) Option
WithChromeFlags add chrome flags.
func WithExtensions ¶ added in v1.3.8
WithExtensions adds chrome extensions.
Provide the paths to the extensions to load.
func WithNoSandbox ¶
WithNoSandbox enable/disable sandbox. Disabled by default.
func WithTimeout ¶
WithTimeout sets the context timeout.
func WithUserDataDir ¶
WithUserDataDir sets the user data directory to a custom path.