mirror of
https://github.com/labring/FastGPT.git
synced 2025-07-23 13:03:50 +00:00

* fix: remove DefaultTeam (#4037) * fix :Get application bound knowledge base information logical rewrite (#4057) * fix :Get application bound knowledge base information logical rewrite * fix :Get application bound knowledge base information logical rewrite * fix :Get application bound knowledge base information logical rewrite * fix :Get application bound knowledge base information logical rewrite * update package * fix: import dataset step error;perf: ai proxy avatar (#4074) * perf: pg config params * perf: ai proxy avatar * fix: import dataset step error * feat: data input ux * perf: app dataset rewite * fix: 文本提取不支持arrayString,arrayNumber等jsonSchema (#4079) * update doc ;perf: model test (#4098) * perf: extract array * update doc * perf: model test * perf: model test * perf: think tag parse (#4102) * chat quote reader (#3912) * init chat quote full text reader * linked structure * dataset data linked * optimize code * fix ts build * test finish * delete log * fix * fix ts * fix ts * remove nextId * initial scroll * fix * fix * perf: chunk read (#4109) * package * perf: chunk read * feat: api dataset support pdf parse;fix: chunk reader auth (#4117) * feat: api dataset support pdf parse * fix: chunk reader auth * feat: invitation link (#3979) * feat: invitation link schema and apis * feat: add invitation link * feat: member status: active, leave, forbidden * fix: expires show hours and minutes * feat: invalid invitation link hint * fix: typo * chore: fix typo & i18n * fix * pref: fe * feat: add ttl index for 30-day-clean-up * perf: invite member code (#4118) * perf: invite member code * fix: ts * fix: model test channel id;fix: quote reader (#4123) * fix: model test channel id * fix: quote reader * fix chat quote reader (#4125) * perf: model test;perf: sidebar trigger (#4127) * fix: import dataset step error;perf: ai proxy avatar (#4074) * perf: pg config params * perf: ai proxy avatar * fix: import dataset step error * feat: data input ux * perf: app dataset rewite * perf: model test * perf: sidebar trigger * lock * update nanoid version * fix: select component ux * fix: ts * fix: vitest * remove test * fix: prompt toolcall ui (#4139) * load log error adapt * fix: prompt toolcall ui * perf: commercial function tip * update package * pref: copy link (#4147) * fix(i18n): namespace (#4143) * hiden dataset source (#4152) * hiden dataset source * perf: reader * chore: move all tests into a single folder (#4160) * fix modal close scroll (#4162) * fix modal close scroll * update refresh * feat: rerank modal select and weight (#4164) * fix loadInitData refresh (#4169) * fix * fix * form input number default & api dataset max token * feat: mix search weight (#4170) * feat: mix search weight * feat: svg render * fix: avatar error remove (#4173) * fix: avatar error remove * fix: index * fix: guide * fix: auth * update package;fix: input data model ui (#4181) * update package * fix: ts * update config * update jieba package * add type sign * fix: input data ui * fix: page title refresh (#4186) * fix: ts * update jieba package * fix: page title refresh * fix: remove member length check when opening invite create modal (#4193) * add env to check internal ip (#4187) * fix: ts * update jieba package * add env to check internal ip * package * fix: jieba * reset package * update config * fix: jieba package * init shell * init version * change team reload * update jieba package (#4200) * update jieba package * package * update package * remove invalid code * action * package (#4201) * package * update package * remove invalid code * package * remove i18n tip (#4202) * doc (#4205) * fix: i18n (#4208) * fix: next config (#4207) * reset package * i18n * update config * i18n * remove log --------- Co-authored-by: Finley Ge <32237950+FinleyGe@users.noreply.github.com> Co-authored-by: gggaaallleee <91131304+gggaaallleee@users.noreply.github.com> Co-authored-by: shilin <39396378+shilin66@users.noreply.github.com> Co-authored-by: heheer <heheer@sealos.io>
66 lines
2.1 KiB
TypeScript
66 lines
2.1 KiB
TypeScript
import { SERVICE_LOCAL_HOST } from './tools';
|
|
|
|
export const isInternalAddress = (url: string): boolean => {
|
|
try {
|
|
const parsedUrl = new URL(url);
|
|
const hostname = parsedUrl.hostname;
|
|
const fullUrl = parsedUrl.toString();
|
|
|
|
// Check for localhost and common internal domains
|
|
if (hostname === SERVICE_LOCAL_HOST) {
|
|
return true;
|
|
}
|
|
|
|
// Metadata endpoints whitelist
|
|
const metadataEndpoints = [
|
|
// AWS
|
|
'http://169.254.169.254/latest/meta-data/',
|
|
// Azure
|
|
'http://169.254.169.254/metadata/instance?api-version=2021-02-01',
|
|
// GCP
|
|
'http://metadata.google.internal/computeMetadata/v1/',
|
|
// Alibaba Cloud
|
|
'http://100.100.100.200/latest/meta-data/',
|
|
// Tencent Cloud
|
|
'http://metadata.tencentyun.com/latest/meta-data/',
|
|
// Huawei Cloud
|
|
'http://169.254.169.254/latest/meta-data/'
|
|
];
|
|
if (metadataEndpoints.some((endpoint) => fullUrl.startsWith(endpoint))) {
|
|
return true;
|
|
}
|
|
|
|
if (process.env.CHECK_INTERNAL_IP !== 'true') return false;
|
|
|
|
// For IP addresses, check if they are internal
|
|
const ipv4Pattern = /^(\d{1,3}\.){3}\d{1,3}$/;
|
|
if (!ipv4Pattern.test(hostname)) {
|
|
return false; // Not an IP address, so it's a domain name - consider it external by default
|
|
}
|
|
|
|
// ... existing IP validation code ...
|
|
const parts = hostname.split('.').map(Number);
|
|
|
|
if (parts.length !== 4 || parts.some((part) => part < 0 || part > 255)) {
|
|
return false;
|
|
}
|
|
|
|
// Only allow public IP ranges
|
|
return (
|
|
parts[0] !== 0 &&
|
|
parts[0] !== 10 &&
|
|
parts[0] !== 127 &&
|
|
!(parts[0] === 169 && parts[1] === 254) &&
|
|
!(parts[0] === 172 && parts[1] >= 16 && parts[1] <= 31) &&
|
|
!(parts[0] === 192 && parts[1] === 168) &&
|
|
!(parts[0] >= 224 && parts[0] <= 239) &&
|
|
!(parts[0] >= 240 && parts[0] <= 255) &&
|
|
!(parts[0] === 100 && parts[1] >= 64 && parts[1] <= 127) &&
|
|
!(parts[0] === 9 && parts[1] === 0) &&
|
|
!(parts[0] === 11 && parts[1] === 0)
|
|
);
|
|
} catch {
|
|
return false; // If URL parsing fails, reject it as potentially unsafe
|
|
}
|
|
};
|