improve: code upgrade (#4231)
parent
e6db7ad1d5
commit
bbef964eb5
@ -0,0 +1,6 @@
|
|||||||
|
from pydantic import BaseModel
|
||||||
|
|
||||||
|
|
||||||
|
class CodeDependency(BaseModel):
|
||||||
|
name: str
|
||||||
|
version: str
|
||||||
@ -0,0 +1,50 @@
|
|||||||
|
acl localnet src 0.0.0.1-0.255.255.255 # RFC 1122 "this" network (LAN)
|
||||||
|
acl localnet src 10.0.0.0/8 # RFC 1918 local private network (LAN)
|
||||||
|
acl localnet src 100.64.0.0/10 # RFC 6598 shared address space (CGN)
|
||||||
|
acl localnet src 169.254.0.0/16 # RFC 3927 link-local (directly plugged) machines
|
||||||
|
acl localnet src 172.16.0.0/12 # RFC 1918 local private network (LAN)
|
||||||
|
acl localnet src 192.168.0.0/16 # RFC 1918 local private network (LAN)
|
||||||
|
acl localnet src fc00::/7 # RFC 4193 local private network range
|
||||||
|
acl localnet src fe80::/10 # RFC 4291 link-local (directly plugged) machines
|
||||||
|
acl SSL_ports port 443
|
||||||
|
acl Safe_ports port 80 # http
|
||||||
|
acl Safe_ports port 21 # ftp
|
||||||
|
acl Safe_ports port 443 # https
|
||||||
|
acl Safe_ports port 70 # gopher
|
||||||
|
acl Safe_ports port 210 # wais
|
||||||
|
acl Safe_ports port 1025-65535 # unregistered ports
|
||||||
|
acl Safe_ports port 280 # http-mgmt
|
||||||
|
acl Safe_ports port 488 # gss-http
|
||||||
|
acl Safe_ports port 591 # filemaker
|
||||||
|
acl Safe_ports port 777 # multiling http
|
||||||
|
acl CONNECT method CONNECT
|
||||||
|
http_access deny !Safe_ports
|
||||||
|
http_access deny CONNECT !SSL_ports
|
||||||
|
http_access allow localhost manager
|
||||||
|
http_access deny manager
|
||||||
|
http_access allow localhost
|
||||||
|
http_access allow localnet
|
||||||
|
http_access deny all
|
||||||
|
|
||||||
|
################################## Proxy Server ################################
|
||||||
|
http_port 3128
|
||||||
|
coredump_dir /var/spool/squid
|
||||||
|
refresh_pattern ^ftp: 1440 20% 10080
|
||||||
|
refresh_pattern ^gopher: 1440 0% 1440
|
||||||
|
refresh_pattern -i (/cgi-bin/|\?) 0 0% 0
|
||||||
|
refresh_pattern \/(Packages|Sources)(|\.bz2|\.gz|\.xz)$ 0 0% 0 refresh-ims
|
||||||
|
refresh_pattern \/Release(|\.gpg)$ 0 0% 0 refresh-ims
|
||||||
|
refresh_pattern \/InRelease$ 0 0% 0 refresh-ims
|
||||||
|
refresh_pattern \/(Translation-.*)(|\.bz2|\.gz|\.xz)$ 0 0% 0 refresh-ims
|
||||||
|
refresh_pattern . 0 20% 4320
|
||||||
|
logfile_rotate 0
|
||||||
|
|
||||||
|
# upstream proxy, set to your own upstream proxy IP to avoid SSRF attacks
|
||||||
|
# cache_peer 172.1.1.1 parent 3128 0 no-query no-digest no-netdb-exchange default
|
||||||
|
|
||||||
|
|
||||||
|
################################## Reverse Proxy To Sandbox ################################
|
||||||
|
http_port 8194 accel vhost
|
||||||
|
cache_peer sandbox parent 8194 0 no-query originserver
|
||||||
|
acl all src all
|
||||||
|
http_access allow all
|
||||||
@ -0,0 +1,94 @@
|
|||||||
|
import type { FC } from 'react'
|
||||||
|
import React, { useCallback, useState } from 'react'
|
||||||
|
import { t } from 'i18next'
|
||||||
|
import type { CodeDependency } from './types'
|
||||||
|
import { ChevronDown } from '@/app/components/base/icons/src/vender/line/arrows'
|
||||||
|
import { PortalToFollowElem, PortalToFollowElemContent, PortalToFollowElemTrigger } from '@/app/components/base/portal-to-follow-elem'
|
||||||
|
import { Check, SearchLg } from '@/app/components/base/icons/src/vender/line/general'
|
||||||
|
import { XCircle } from '@/app/components/base/icons/src/vender/solid/general'
|
||||||
|
|
||||||
|
type Props = {
|
||||||
|
value: CodeDependency
|
||||||
|
available_dependencies: CodeDependency[]
|
||||||
|
onChange: (dependency: CodeDependency) => void
|
||||||
|
}
|
||||||
|
|
||||||
|
const DependencyPicker: FC<Props> = ({
|
||||||
|
available_dependencies,
|
||||||
|
value,
|
||||||
|
onChange,
|
||||||
|
}) => {
|
||||||
|
const [open, setOpen] = useState(false)
|
||||||
|
const [searchText, setSearchText] = useState('')
|
||||||
|
|
||||||
|
const handleChange = useCallback((dependency: CodeDependency) => {
|
||||||
|
return () => {
|
||||||
|
setOpen(false)
|
||||||
|
onChange(dependency)
|
||||||
|
}
|
||||||
|
}, [onChange])
|
||||||
|
|
||||||
|
return (
|
||||||
|
<PortalToFollowElem
|
||||||
|
open={open}
|
||||||
|
onOpenChange={setOpen}
|
||||||
|
placement='bottom-start'
|
||||||
|
offset={4}
|
||||||
|
>
|
||||||
|
<PortalToFollowElemTrigger onClick={() => setOpen(!open)} className='flex-grow cursor-pointer'>
|
||||||
|
<div className='flex items-center h-8 justify-between px-2.5 rounded-lg border-0 bg-gray-100 text-gray-900 text-[13px]'>
|
||||||
|
<div className='grow w-0 truncate' title={value.name}>{value.name}</div>
|
||||||
|
<ChevronDown className='shrink-0 w-3.5 h-3.5 text-gray-700' />
|
||||||
|
</div>
|
||||||
|
</PortalToFollowElemTrigger>
|
||||||
|
<PortalToFollowElemContent style={{
|
||||||
|
zIndex: 100,
|
||||||
|
}}>
|
||||||
|
<div className='p-1 bg-white rounded-lg shadow-sm' style={{
|
||||||
|
width: 350,
|
||||||
|
}}>
|
||||||
|
<div
|
||||||
|
className='shadow-sm bg-white mb-2 mx-1 flex items-center px-2 rounded-lg bg-gray-100'
|
||||||
|
>
|
||||||
|
<SearchLg className='shrink-0 ml-[1px] mr-[5px] w-3.5 h-3.5 text-gray-400' />
|
||||||
|
<input
|
||||||
|
value={searchText}
|
||||||
|
className='grow px-0.5 py-[7px] text-[13px] text-gray-700 bg-transparent appearance-none outline-none caret-primary-600 placeholder:text-gray-400'
|
||||||
|
placeholder={t('workflow.nodes.code.searchDependencies') || ''}
|
||||||
|
onChange={e => setSearchText(e.target.value)}
|
||||||
|
autoFocus
|
||||||
|
/>
|
||||||
|
{
|
||||||
|
searchText && (
|
||||||
|
<div
|
||||||
|
className='flex items-center justify-center ml-[5px] w-[18px] h-[18px] cursor-pointer'
|
||||||
|
onClick={() => setSearchText('')}
|
||||||
|
>
|
||||||
|
<XCircle className='w-[14px] h-[14px] text-gray-400' />
|
||||||
|
</div>
|
||||||
|
)
|
||||||
|
}
|
||||||
|
</div>
|
||||||
|
<div className='max-h-[30vh] overflow-y-auto'>
|
||||||
|
{available_dependencies.filter((v) => {
|
||||||
|
if (!searchText)
|
||||||
|
return true
|
||||||
|
return v.name.toLowerCase().includes(searchText.toLowerCase())
|
||||||
|
}).map(dependency => (
|
||||||
|
<div
|
||||||
|
key={dependency.name}
|
||||||
|
className='flex items-center h-[30px] justify-between pl-3 pr-2 rounded-lg hover:bg-gray-100 text-gray-900 text-[13px] cursor-pointer'
|
||||||
|
onClick={handleChange(dependency)}
|
||||||
|
>
|
||||||
|
<div className='w-0 grow truncate'>{dependency.name}</div>
|
||||||
|
{dependency.name === value.name && <Check className='shrink-0 w-4 h-4 text-primary-600' />}
|
||||||
|
</div>
|
||||||
|
))}
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</PortalToFollowElemContent>
|
||||||
|
</PortalToFollowElem>
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
|
export default React.memo(DependencyPicker)
|
||||||
@ -0,0 +1,36 @@
|
|||||||
|
import type { FC } from 'react'
|
||||||
|
import React from 'react'
|
||||||
|
import RemoveButton from '../_base/components/remove-button'
|
||||||
|
import type { CodeDependency } from './types'
|
||||||
|
import DependencyPicker from './dependency-picker'
|
||||||
|
|
||||||
|
type Props = {
|
||||||
|
available_dependencies: CodeDependency[]
|
||||||
|
dependencies: CodeDependency[]
|
||||||
|
handleRemove: (index: number) => void
|
||||||
|
handleChange: (index: number, dependency: CodeDependency) => void
|
||||||
|
}
|
||||||
|
|
||||||
|
const Dependencies: FC<Props> = ({
|
||||||
|
available_dependencies, dependencies, handleRemove, handleChange,
|
||||||
|
}) => {
|
||||||
|
return (
|
||||||
|
<div className='space-y-2'>
|
||||||
|
{dependencies.map((dependency, index) => (
|
||||||
|
<div className='flex items-center space-x-1' key={index}>
|
||||||
|
<DependencyPicker
|
||||||
|
value={dependency}
|
||||||
|
available_dependencies={available_dependencies}
|
||||||
|
onChange={dependency => handleChange(index, dependency)}
|
||||||
|
/>
|
||||||
|
<RemoveButton
|
||||||
|
className='!p-2 !bg-gray-100 hover:!bg-gray-200'
|
||||||
|
onClick={() => handleRemove(index)}
|
||||||
|
/>
|
||||||
|
</div>
|
||||||
|
))}
|
||||||
|
</div>
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
|
export default React.memo(Dependencies)
|
||||||
Loading…
Reference in New Issue