Skip to content

Commit

Permalink
Merge pull request #34 from mendableai/nsc/returnOnlyUrls
Browse files Browse the repository at this point in the history
Implements the ability for the crawler to output all the links it found, without scraping
  • Loading branch information
rafaelsideguide authored Apr 24, 2024
2 parents 523dd15 + 07e93ee commit f189589
Show file tree
Hide file tree
Showing 4 changed files with 35 additions and 9 deletions.
15 changes: 12 additions & 3 deletions apps/api/requests.http
Original file line number Diff line number Diff line change
Expand Up @@ -13,15 +13,24 @@ GET http://localhost:3002/v0/jobs/active HTTP/1.1


### Scrape Website
POST https://api.firecrawl.dev/v0/scrape HTTP/1.1
POST http://localhost:3002/v0/crawl HTTP/1.1
Authorization: Bearer
content-type: application/json

{
"url":"https://www.mendable.ai"
"url":"https://www.mendable.ai",
"crawlerOptions": {
"returnOnlyUrls": true
}
}








### Scrape Website
POST http://localhost:3002/v0/scrape HTTP/1.1
Authorization: Bearer
Expand All @@ -34,7 +43,7 @@ content-type: application/json


### Check Job Status
GET http://localhost:3002/v0/crawl/status/333ab225-dc3e-418b-9d4b-8fb833cbaf89 HTTP/1.1
GET http://localhost:3002/v0/crawl/status/a6053912-d602-4709-841f-3d2cb46fea0a HTTP/1.1
Authorization: Bearer

### Get Job Result
Expand Down
4 changes: 4 additions & 0 deletions apps/api/src/lib/entities.ts
Original file line number Diff line number Diff line change
Expand Up @@ -38,6 +38,10 @@ export type WebScraperOptions = {
concurrentRequests?: number;
};

export interface DocumentUrl {
url: string;
}

export class Document {
id?: string;
url?: string; // Used only in /search for now
Expand Down
16 changes: 12 additions & 4 deletions apps/api/src/main/runWebScraper.ts
Original file line number Diff line number Diff line change
@@ -1,9 +1,10 @@
import { Job } from "bull";
import { CrawlResult, WebScraperOptions } from "../types";
import { WebScraperDataProvider } from "../scraper/WebScraper";
import { Progress } from "../lib/entities";
import { DocumentUrl, Progress } from "../lib/entities";
import { billTeam } from "../services/billing/credit_billing";
import { Document } from "../lib/entities";

export async function startWebScraperPipeline({
job,
}: {
Expand Down Expand Up @@ -47,7 +48,7 @@ export async function runWebScraper({
}): Promise<{
success: boolean;
message: string;
docs: CrawlResult[];
docs: Document[] | DocumentUrl[];
}> {
try {
const provider = new WebScraperDataProvider();
Expand All @@ -68,7 +69,7 @@ export async function runWebScraper({
}
const docs = (await provider.getDocuments(false, (progress: Progress) => {
inProgress(progress);
})) as CrawlResult[];
})) as Document[];

if (docs.length === 0) {
return {
Expand All @@ -79,7 +80,14 @@ export async function runWebScraper({
}

// remove docs with empty content
const filteredDocs = docs.filter((doc) => doc.content.trim().length > 0);
const filteredDocs = crawlerOptions.returnOnlyUrls
? docs.map((doc) => {
if (doc.metadata.sourceURL) {
return { url: doc.metadata.sourceURL };
}
})
: docs.filter((doc) => doc.content.trim().length > 0);


const { success, credit_usage } = await billTeam(
team_id,
Expand Down
9 changes: 7 additions & 2 deletions apps/api/src/scraper/WebScraper/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -80,11 +80,16 @@ export class WebScraperDataProvider {
});
let links = await crawler.start(inProgress, 5, this.limit);
if (this.returnOnlyUrls) {
inProgress({
current: links.length,
total: links.length,
status: "COMPLETED",
currentDocumentUrl: this.urls[0],
});
return links.map((url) => ({
content: "",
markdown: "",
metadata: { sourceURL: url },
provider: "web",
type: "text",
}));
}

Expand Down

0 comments on commit f189589

Please sign in to comment.