ensure max crawl size and max crawl timeout values are set to 0 when unused, instead of null (#1167)
- convert None->0 when creating CrawlJob - ensure frontend sends 0 not null - make input model require 'int = 0' instead of 'Optional[int] = 0'
This commit is contained in:
parent
ab76f0f394
commit
9159c7c914
@ -98,8 +98,8 @@ class K8sAPI:
|
|||||||
"oid": oid,
|
"oid": oid,
|
||||||
"userid": userid,
|
"userid": userid,
|
||||||
"scale": scale,
|
"scale": scale,
|
||||||
"expire_time": crawl_expire_time,
|
"expire_time": crawl_expire_time or 0,
|
||||||
"max_crawl_size": max_crawl_size,
|
"max_crawl_size": max_crawl_size or 0,
|
||||||
"manual": "1" if manual else "0",
|
"manual": "1" if manual else "0",
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@ -128,8 +128,8 @@ class CrawlConfigIn(BaseModel):
|
|||||||
autoAddCollections: Optional[List[UUID4]] = []
|
autoAddCollections: Optional[List[UUID4]] = []
|
||||||
tags: Optional[List[str]] = []
|
tags: Optional[List[str]] = []
|
||||||
|
|
||||||
crawlTimeout: Optional[int] = 0
|
crawlTimeout: int = 0
|
||||||
maxCrawlSize: Optional[int] = 0
|
maxCrawlSize: int = 0
|
||||||
scale: Optional[conint(ge=1, le=MAX_CRAWL_SCALE)] = 1
|
scale: Optional[conint(ge=1, le=MAX_CRAWL_SCALE)] = 1
|
||||||
|
|
||||||
crawlFilenameTemplate: Optional[str]
|
crawlFilenameTemplate: Optional[str]
|
||||||
|
|||||||
@ -280,7 +280,7 @@ class BtrixOperator(K8sAPI):
|
|||||||
started=data.parent["metadata"]["creationTimestamp"],
|
started=data.parent["metadata"]["creationTimestamp"],
|
||||||
stopping=spec.get("stopping", False),
|
stopping=spec.get("stopping", False),
|
||||||
expire_time=from_k8s_date(spec.get("expireTime")),
|
expire_time=from_k8s_date(spec.get("expireTime")),
|
||||||
max_crawl_size=int(configmap.get("MAX_CRAWL_SIZE", "0")),
|
max_crawl_size=int(spec.get("maxCrawlSize") or 0),
|
||||||
scheduled=spec.get("manual") != "1",
|
scheduled=spec.get("manual") != "1",
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|||||||
@ -78,11 +78,11 @@ type FormState = {
|
|||||||
includeLinkedPages: boolean;
|
includeLinkedPages: boolean;
|
||||||
useSitemap: boolean;
|
useSitemap: boolean;
|
||||||
customIncludeUrlList: string;
|
customIncludeUrlList: string;
|
||||||
crawlTimeoutMinutes: number | null;
|
crawlTimeoutMinutes: number;
|
||||||
behaviorTimeoutSeconds: number | null;
|
behaviorTimeoutSeconds: number | null;
|
||||||
pageLoadTimeoutSeconds: number | null;
|
pageLoadTimeoutSeconds: number | null;
|
||||||
pageExtraDelaySeconds: number | null;
|
pageExtraDelaySeconds: number | null;
|
||||||
maxCrawlSizeGB: number | null;
|
maxCrawlSizeGB: number;
|
||||||
maxScopeDepth: number | null;
|
maxScopeDepth: number | null;
|
||||||
scopeType: WorkflowParams["config"]["scopeType"];
|
scopeType: WorkflowParams["config"]["scopeType"];
|
||||||
exclusions: WorkflowParams["config"]["exclude"];
|
exclusions: WorkflowParams["config"]["exclude"];
|
||||||
@ -153,7 +153,7 @@ const getDefaultFormState = (): FormState => ({
|
|||||||
includeLinkedPages: false,
|
includeLinkedPages: false,
|
||||||
useSitemap: true,
|
useSitemap: true,
|
||||||
customIncludeUrlList: "",
|
customIncludeUrlList: "",
|
||||||
crawlTimeoutMinutes: null,
|
crawlTimeoutMinutes: 0,
|
||||||
maxCrawlSizeGB: 0,
|
maxCrawlSizeGB: 0,
|
||||||
behaviorTimeoutSeconds: null,
|
behaviorTimeoutSeconds: null,
|
||||||
pageLoadTimeoutSeconds: null,
|
pageLoadTimeoutSeconds: null,
|
||||||
@ -488,12 +488,12 @@ export class CrawlConfigEditor extends LiteElement {
|
|||||||
formState.autoAddCollections = this.initialWorkflow.autoAddCollections;
|
formState.autoAddCollections = this.initialWorkflow.autoAddCollections;
|
||||||
}
|
}
|
||||||
|
|
||||||
const secondsToMinutes = (value: any, fallback: number | null) => {
|
const secondsToMinutes = (value: any, fallback: number = 0) => {
|
||||||
if (typeof value === "number" && value > 0) return value / 60;
|
if (typeof value === "number" && value > 0) return value / 60;
|
||||||
return fallback;
|
return fallback;
|
||||||
};
|
};
|
||||||
|
|
||||||
const bytesToGB = (value: any, fallback: number | null) => {
|
const bytesToGB = (value: any, fallback: number = 0) => {
|
||||||
if (typeof value === "number" && value > 0)
|
if (typeof value === "number" && value > 0)
|
||||||
return Math.floor(value / BYTES_PER_GB);
|
return Math.floor(value / BYTES_PER_GB);
|
||||||
return fallback;
|
return fallback;
|
||||||
@ -2147,12 +2147,8 @@ https://archiveweb.page/images/${"logo.svg"}`}
|
|||||||
profileid: this.formState.browserProfile?.id || "",
|
profileid: this.formState.browserProfile?.id || "",
|
||||||
runNow: this.formState.runNow || this.formState.scheduleType === "now",
|
runNow: this.formState.runNow || this.formState.scheduleType === "now",
|
||||||
schedule: this.formState.scheduleType === "cron" ? this.utcSchedule : "",
|
schedule: this.formState.scheduleType === "cron" ? this.utcSchedule : "",
|
||||||
crawlTimeout: this.formState.crawlTimeoutMinutes
|
crawlTimeout: this.formState.crawlTimeoutMinutes * 60,
|
||||||
? this.formState.crawlTimeoutMinutes * 60
|
maxCrawlSize: this.formState.maxCrawlSizeGB * BYTES_PER_GB,
|
||||||
: null,
|
|
||||||
maxCrawlSize: this.formState.maxCrawlSizeGB
|
|
||||||
? this.formState.maxCrawlSizeGB * BYTES_PER_GB
|
|
||||||
: null,
|
|
||||||
tags: this.formState.tags,
|
tags: this.formState.tags,
|
||||||
autoAddCollections: this.formState.autoAddCollections,
|
autoAddCollections: this.formState.autoAddCollections,
|
||||||
config: {
|
config: {
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user