Documentation ¶
Overview ¶
Package firecrawl provides a client for interacting with the Firecrawl API.
Index ¶
- type CancelCrawlJobResponse
- type CrawlParams
- type CrawlResponse
- type CrawlStatusResponse
- type FirecrawlApp
- func (app *FirecrawlApp) AsyncCrawlURL(url string, params *CrawlParams, idempotencyKey *string) (*CrawlResponse, error)
- func (app *FirecrawlApp) CancelCrawlJob(ID string) (string, error)
- func (app *FirecrawlApp) CheckCrawlStatus(ID string) (*CrawlStatusResponse, error)
- func (app *FirecrawlApp) CrawlURL(url string, params *CrawlParams, idempotencyKey *string, pollInterval ...int) (*CrawlStatusResponse, error)
- func (app *FirecrawlApp) MapURL(url string, params *MapParams) (*MapResponse, error)
- func (app *FirecrawlApp) ScrapeURL(url string, params *ScrapeParams) (*FirecrawlDocument, error)
- func (app *FirecrawlApp) Search(query string, params *any) (any, error)
- type FirecrawlDocument
- type FirecrawlDocumentMetadata
- type MapParams
- type MapResponse
- type ScrapeParams
- type ScrapeResponse
- type StringOrStringSlice
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type CancelCrawlJobResponse ¶
CancelCrawlJobResponse represents the response for canceling a crawl job
type CrawlParams ¶
type CrawlParams struct { ScrapeOptions ScrapeParams `json:"scrapeOptions"` Webhook *string `json:"webhook,omitempty"` Limit *int `json:"limit,omitempty"` IncludePaths []string `json:"includePaths,omitempty"` ExcludePaths []string `json:"excludePaths,omitempty"` MaxDepth *int `json:"maxDepth,omitempty"` AllowBackwardLinks *bool `json:"allowBackwardLinks,omitempty"` AllowExternalLinks *bool `json:"allowExternalLinks,omitempty"` IgnoreSitemap *bool `json:"ignoreSitemap,omitempty"` }
CrawlParams represents the parameters for a crawl request.
type CrawlResponse ¶
type CrawlResponse struct { Success bool `json:"success"` ID string `json:"id,omitempty"` URL string `json:"url,omitempty"` }
CrawlResponse represents the response for crawling operations
type CrawlStatusResponse ¶
type CrawlStatusResponse struct { Status string `json:"status"` Total int `json:"total,omitempty"` Completed int `json:"completed,omitempty"` CreditsUsed int `json:"creditsUsed,omitempty"` ExpiresAt string `json:"expiresAt,omitempty"` Next *string `json:"next,omitempty"` Data []*FirecrawlDocument `json:"data,omitempty"` }
CrawlStatusResponse (old JobStatusResponse) represents the response for checking crawl job
type FirecrawlApp ¶
FirecrawlApp represents a client for the Firecrawl API.
func NewFirecrawlApp ¶
func NewFirecrawlApp(apiKey, apiURL string) (*FirecrawlApp, error)
NewFirecrawlApp creates a new instance of FirecrawlApp with the provided API key and API URL. If the API key or API URL is not provided, it attempts to retrieve them from environment variables. If the API key is still not found, it returns an error.
Parameters:
- apiKey: The API key for authenticating with the Firecrawl API. If empty, it will be retrieved from the FIRECRAWL_API_KEY environment variable.
- apiURL: The base URL for the Firecrawl API. If empty, it will be retrieved from the FIRECRAWL_API_URL environment variable, defaulting to "https://api.firecrawl.dev".
Returns:
- *FirecrawlApp: A new instance of FirecrawlApp configured with the provided or retrieved API key and API URL.
- error: An error if the API key is not provided or retrieved.
func (*FirecrawlApp) AsyncCrawlURL ¶
func (app *FirecrawlApp) AsyncCrawlURL(url string, params *CrawlParams, idempotencyKey *string) (*CrawlResponse, error)
CrawlURL starts a crawl job for the specified URL using the Firecrawl API.
Parameters:
- url: The URL to crawl.
- params: Optional parameters for the crawl request.
- idempotencyKey: An optional idempotency key to ensure the request is idempotent.
Returns:
- *CrawlResponse: The crawl response with id.
- error: An error if the crawl request fails.
func (*FirecrawlApp) CancelCrawlJob ¶
func (app *FirecrawlApp) CancelCrawlJob(ID string) (string, error)
CancelCrawlJob cancels a crawl job using the Firecrawl API.
Parameters:
- ID: The ID of the crawl job to cancel.
Returns:
- string: The status of the crawl job after cancellation.
- error: An error if the crawl job cancellation request fails.
func (*FirecrawlApp) CheckCrawlStatus ¶
func (app *FirecrawlApp) CheckCrawlStatus(ID string) (*CrawlStatusResponse, error)
CheckCrawlStatus checks the status of a crawl job using the Firecrawl API.
Parameters:
- ID: The ID of the crawl job to check.
Returns:
- *CrawlStatusResponse: The status of the crawl job.
- error: An error if the crawl status check request fails.
func (*FirecrawlApp) CrawlURL ¶
func (app *FirecrawlApp) CrawlURL(url string, params *CrawlParams, idempotencyKey *string, pollInterval ...int) (*CrawlStatusResponse, error)
CrawlURL starts a crawl job for the specified URL using the Firecrawl API.
Parameters:
- url: The URL to crawl.
- params: Optional parameters for the crawl request.
- idempotencyKey: An optional idempotency key to ensure the request is idempotent (can be nil).
- pollInterval: An optional interval (in seconds) at which to poll the job status. Default is 2 seconds.
Returns:
- CrawlStatusResponse: The crawl result if the job is completed.
- error: An error if the crawl request fails.
func (*FirecrawlApp) MapURL ¶
func (app *FirecrawlApp) MapURL(url string, params *MapParams) (*MapResponse, error)
MapURL initiates a mapping operation for a URL using the Firecrawl API.
Parameters:
- url: The URL to map.
- params: Optional parameters for the mapping request.
Returns:
- *MapResponse: The response from the mapping operation.
- error: An error if the mapping request fails.
func (*FirecrawlApp) ScrapeURL ¶
func (app *FirecrawlApp) ScrapeURL(url string, params *ScrapeParams) (*FirecrawlDocument, error)
ScrapeURL scrapes the content of the specified URL using the Firecrawl API.
Parameters:
- url: The URL to be scraped.
- params: Optional parameters for the scrape request, including extractor options for LLM extraction.
Returns:
- *FirecrawlDocument or *FirecrawlDocumentV0: The scraped document data depending on the API version.
- error: An error if the scrape request fails.
func (*FirecrawlApp) Search ¶
func (app *FirecrawlApp) Search(query string, params *any) (any, error)
SearchURL searches for a URL using the Firecrawl API.
Parameters:
- url: The URL to search for.
- params: Optional parameters for the search request.
- error: An error if the search request fails.
Search is not implemented in API version 1.0.0.
type FirecrawlDocument ¶
type FirecrawlDocument struct { Markdown string `json:"markdown,omitempty"` HTML string `json:"html,omitempty"` RawHTML string `json:"rawHtml,omitempty"` Screenshot string `json:"screenshot,omitempty"` Links []string `json:"links,omitempty"` Metadata *FirecrawlDocumentMetadata `json:"metadata,omitempty"` }
FirecrawlDocument represents a document in Firecrawl
type FirecrawlDocumentMetadata ¶
type FirecrawlDocumentMetadata struct { Title *string `json:"title,omitempty"` Description *StringOrStringSlice `json:"description,omitempty"` Language *string `json:"language,omitempty"` Keywords *StringOrStringSlice `json:"keywords,omitempty"` Robots *StringOrStringSlice `json:"robots,omitempty"` OGTitle *string `json:"ogTitle,omitempty"` OGDescription *string `json:"ogDescription,omitempty"` OGURL *string `json:"ogUrl,omitempty"` OGImage *string `json:"ogImage,omitempty"` OGAudio *string `json:"ogAudio,omitempty"` OGDeterminer *string `json:"ogDeterminer,omitempty"` OGLocale *string `json:"ogLocale,omitempty"` OGLocaleAlternate []*string `json:"ogLocaleAlternate,omitempty"` OGSiteName *string `json:"ogSiteName,omitempty"` OGVideo *string `json:"ogVideo,omitempty"` DCTermsCreated *string `json:"dctermsCreated,omitempty"` DCDateCreated *string `json:"dcDateCreated,omitempty"` DCDate *string `json:"dcDate,omitempty"` DCTermsType *string `json:"dctermsType,omitempty"` DCType *string `json:"dcType,omitempty"` DCTermsAudience *string `json:"dctermsAudience,omitempty"` DCTermsSubject *string `json:"dctermsSubject,omitempty"` DCSubject *string `json:"dcSubject,omitempty"` DCDescription *string `json:"dcDescription,omitempty"` DCTermsKeywords *string `json:"dctermsKeywords,omitempty"` ModifiedTime *string `json:"modifiedTime,omitempty"` PublishedTime *string `json:"publishedTime,omitempty"` ArticleTag *string `json:"articleTag,omitempty"` ArticleSection *string `json:"articleSection,omitempty"` SourceURL *string `json:"sourceURL,omitempty"` StatusCode *int `json:"statusCode,omitempty"` Error *string `json:"error,omitempty"` }
FirecrawlDocumentMetadata represents metadata for a Firecrawl document
type MapParams ¶
type MapParams struct { IncludeSubdomains *bool `json:"includeSubdomains,omitempty"` Search *string `json:"search,omitempty"` IgnoreSitemap *bool `json:"ignoreSitemap,omitempty"` Limit *int `json:"limit,omitempty"` }
MapParams represents the parameters for a map request.
type MapResponse ¶
type MapResponse struct { Success bool `json:"success"` Links []string `json:"links,omitempty"` Error string `json:"error,omitempty"` }
MapResponse represents the response for mapping operations
type ScrapeParams ¶
type ScrapeParams struct { Formats []string `json:"formats,omitempty"` Headers *map[string]string `json:"headers,omitempty"` IncludeTags []string `json:"includeTags,omitempty"` ExcludeTags []string `json:"excludeTags,omitempty"` OnlyMainContent *bool `json:"onlyMainContent,omitempty"` WaitFor *int `json:"waitFor,omitempty"` ParsePDF *bool `json:"parsePDF,omitempty"` Timeout *int `json:"timeout,omitempty"` }
ScrapeParams represents the parameters for a scrape request.
type ScrapeResponse ¶
type ScrapeResponse struct { Success bool `json:"success"` Data *FirecrawlDocument `json:"data,omitempty"` }
ScrapeResponse represents the response for scraping operations
type StringOrStringSlice ¶
type StringOrStringSlice []string
func (*StringOrStringSlice) UnmarshalJSON ¶
func (s *StringOrStringSlice) UnmarshalJSON(data []byte) error