mirror of
				https://github.com/pelican-dev/panel.git
				synced 2025-10-26 05:56:51 +01:00 
			
		
		
		
	Show ipv6 with correct in-url syntax (#3776)
This commit is contained in:
		
							parent
							
								
									e8e2911a92
								
							
						
					
					
						commit
						622b939f00
					
				| @ -4,7 +4,7 @@ import { faEthernet, faHdd, faMemory, faMicrochip, faServer } from '@fortawesome | |||||||
| import { Link } from 'react-router-dom'; | import { Link } from 'react-router-dom'; | ||||||
| import { Server } from '@/api/server/getServer'; | import { Server } from '@/api/server/getServer'; | ||||||
| import getServerResourceUsage, { ServerPowerState, ServerStats } from '@/api/server/getServerResourceUsage'; | import getServerResourceUsage, { ServerPowerState, ServerStats } from '@/api/server/getServerResourceUsage'; | ||||||
| import { bytesToHuman, megabytesToHuman } from '@/helpers'; | import { bytesToHuman, megabytesToHuman, formatIp } from '@/helpers'; | ||||||
| import tw from 'twin.macro'; | import tw from 'twin.macro'; | ||||||
| import GreyRowBox from '@/components/elements/GreyRowBox'; | import GreyRowBox from '@/components/elements/GreyRowBox'; | ||||||
| import Spinner from '@/components/elements/Spinner'; | import Spinner from '@/components/elements/Spinner'; | ||||||
| @ -97,7 +97,7 @@ export default ({ server, className }: { server: Server; className?: string }) = | |||||||
|                     { |                     { | ||||||
|                         server.allocations.filter(alloc => alloc.isDefault).map(allocation => ( |                         server.allocations.filter(alloc => alloc.isDefault).map(allocation => ( | ||||||
|                             <React.Fragment key={allocation.ip + allocation.port.toString()}> |                             <React.Fragment key={allocation.ip + allocation.port.toString()}> | ||||||
|                                 {allocation.alias || allocation.ip}:{allocation.port} |                                 {allocation.alias || formatIp(allocation.ip)}:{allocation.port} | ||||||
|                             </React.Fragment> |                             </React.Fragment> | ||||||
|                         )) |                         )) | ||||||
|                     } |                     } | ||||||
|  | |||||||
| @ -13,7 +13,7 @@ import { Link } from 'react-router-dom'; | |||||||
| import styled from 'styled-components/macro'; | import styled from 'styled-components/macro'; | ||||||
| import tw from 'twin.macro'; | import tw from 'twin.macro'; | ||||||
| import Input from '@/components/elements/Input'; | import Input from '@/components/elements/Input'; | ||||||
| 
 | import { formatIp } from '@/helpers'; | ||||||
| type Props = RequiredModalProps; | type Props = RequiredModalProps; | ||||||
| 
 | 
 | ||||||
| interface Values { | interface Values { | ||||||
| @ -109,7 +109,7 @@ export default ({ ...props }: Props) => { | |||||||
|                                         <p css={tw`mt-1 text-xs text-neutral-400`}> |                                         <p css={tw`mt-1 text-xs text-neutral-400`}> | ||||||
|                                             { |                                             { | ||||||
|                                                 server.allocations.filter(alloc => alloc.isDefault).map(allocation => ( |                                                 server.allocations.filter(alloc => alloc.isDefault).map(allocation => ( | ||||||
|                                                     <span key={allocation.ip + allocation.port.toString()}>{allocation.alias || allocation.ip}:{allocation.port}</span> |                                                     <span key={allocation.ip + allocation.port.toString()}>{allocation.alias || formatIp(allocation.ip)}:{allocation.port}</span> | ||||||
|                                                 )) |                                                 )) | ||||||
|                                             } |                                             } | ||||||
|                                         </p> |                                         </p> | ||||||
|  | |||||||
| @ -2,7 +2,7 @@ import React, { useEffect, useState } from 'react'; | |||||||
| import tw, { TwStyle } from 'twin.macro'; | import tw, { TwStyle } from 'twin.macro'; | ||||||
| import { faCircle, faEthernet, faHdd, faMemory, faMicrochip, faServer } from '@fortawesome/free-solid-svg-icons'; | import { faCircle, faEthernet, faHdd, faMemory, faMicrochip, faServer } from '@fortawesome/free-solid-svg-icons'; | ||||||
| import { FontAwesomeIcon } from '@fortawesome/react-fontawesome'; | import { FontAwesomeIcon } from '@fortawesome/react-fontawesome'; | ||||||
| import { bytesToHuman, megabytesToHuman } from '@/helpers'; | import { bytesToHuman, megabytesToHuman, formatIp } from '@/helpers'; | ||||||
| import TitledGreyBox from '@/components/elements/TitledGreyBox'; | import TitledGreyBox from '@/components/elements/TitledGreyBox'; | ||||||
| import { ServerContext } from '@/state/server'; | import { ServerContext } from '@/state/server'; | ||||||
| import CopyOnClick from '@/components/elements/CopyOnClick'; | import CopyOnClick from '@/components/elements/CopyOnClick'; | ||||||
| @ -72,7 +72,7 @@ const ServerDetailsBlock = () => { | |||||||
|     const isTransferring = ServerContext.useStoreState(state => state.server.data!.isTransferring); |     const isTransferring = ServerContext.useStoreState(state => state.server.data!.isTransferring); | ||||||
|     const limits = ServerContext.useStoreState(state => state.server.data!.limits); |     const limits = ServerContext.useStoreState(state => state.server.data!.limits); | ||||||
|     const primaryAllocation = ServerContext.useStoreState(state => state.server.data!.allocations.filter(alloc => alloc.isDefault).map( |     const primaryAllocation = ServerContext.useStoreState(state => state.server.data!.allocations.filter(alloc => alloc.isDefault).map( | ||||||
|         allocation => (allocation.alias || allocation.ip) + ':' + allocation.port, |         allocation => (allocation.alias || formatIp(allocation.ip)) + ':' + allocation.port, | ||||||
|     )).toString(); |     )).toString(); | ||||||
| 
 | 
 | ||||||
|     const diskLimit = limits.disk ? megabytesToHuman(limits.disk) : 'Unlimited'; |     const diskLimit = limits.disk ? megabytesToHuman(limits.disk) : 'Unlimited'; | ||||||
|  | |||||||
| @ -18,6 +18,7 @@ import CopyOnClick from '@/components/elements/CopyOnClick'; | |||||||
| import DeleteAllocationButton from '@/components/server/network/DeleteAllocationButton'; | import DeleteAllocationButton from '@/components/server/network/DeleteAllocationButton'; | ||||||
| import setPrimaryServerAllocation from '@/api/server/network/setPrimaryServerAllocation'; | import setPrimaryServerAllocation from '@/api/server/network/setPrimaryServerAllocation'; | ||||||
| import getServerAllocations from '@/api/swr/getServerAllocations'; | import getServerAllocations from '@/api/swr/getServerAllocations'; | ||||||
|  | import { formatIp } from '@/helpers'; | ||||||
| 
 | 
 | ||||||
| const Code = styled.code`${tw`font-mono py-1 px-2 bg-neutral-900 rounded text-sm inline-block`}`; | const Code = styled.code`${tw`font-mono py-1 px-2 bg-neutral-900 rounded text-sm inline-block`}`; | ||||||
| const Label = styled.label`${tw`uppercase text-xs mt-1 text-neutral-400 block px-1 select-none transition-colors duration-150`}`; | const Label = styled.label`${tw`uppercase text-xs mt-1 text-neutral-400 block px-1 select-none transition-colors duration-150`}`; | ||||||
| @ -66,7 +67,7 @@ const AllocationRow = ({ allocation }: Props) => { | |||||||
|                 <div css={tw`mr-4 flex-1 md:w-40`}> |                 <div css={tw`mr-4 flex-1 md:w-40`}> | ||||||
|                     {allocation.alias ? |                     {allocation.alias ? | ||||||
|                         <CopyOnClick text={allocation.alias}><Code css={tw`w-40 truncate`}>{allocation.alias}</Code></CopyOnClick> : |                         <CopyOnClick text={allocation.alias}><Code css={tw`w-40 truncate`}>{allocation.alias}</Code></CopyOnClick> : | ||||||
|                         <CopyOnClick text={allocation.ip}><Code>{allocation.ip}</Code></CopyOnClick>} |                         <CopyOnClick text={formatIp(allocation.ip)}><Code>{formatIp(allocation.ip)}</Code></CopyOnClick>} | ||||||
|                     <Label>{allocation.alias ? 'Hostname' : 'IP Address'}</Label> |                     <Label>{allocation.alias ? 'Hostname' : 'IP Address'}</Label> | ||||||
|                 </div> |                 </div> | ||||||
|                 <div css={tw`w-16 md:w-24 overflow-hidden`}> |                 <div css={tw`w-16 md:w-24 overflow-hidden`}> | ||||||
|  | |||||||
| @ -13,6 +13,7 @@ import { LinkButton } from '@/components/elements/Button'; | |||||||
| import ServerContentBlock from '@/components/elements/ServerContentBlock'; | import ServerContentBlock from '@/components/elements/ServerContentBlock'; | ||||||
| import isEqual from 'react-fast-compare'; | import isEqual from 'react-fast-compare'; | ||||||
| import CopyOnClick from '@/components/elements/CopyOnClick'; | import CopyOnClick from '@/components/elements/CopyOnClick'; | ||||||
|  | import { formatIp } from '@/helpers'; | ||||||
| 
 | 
 | ||||||
| export default () => { | export default () => { | ||||||
|     const username = useStoreState(state => state.user.data!.username); |     const username = useStoreState(state => state.user.data!.username); | ||||||
| @ -30,10 +31,10 @@ export default () => { | |||||||
|                         <TitledGreyBox title={'SFTP Details'} css={tw`mb-6 md:mb-10`}> |                         <TitledGreyBox title={'SFTP Details'} css={tw`mb-6 md:mb-10`}> | ||||||
|                             <div> |                             <div> | ||||||
|                                 <Label>Server Address</Label> |                                 <Label>Server Address</Label> | ||||||
|                                 <CopyOnClick text={`sftp://${sftp.ip}:${sftp.port}`}> |                                 <CopyOnClick text={`sftp://${formatIp(sftp.ip)}:${sftp.port}`}> | ||||||
|                                     <Input |                                     <Input | ||||||
|                                         type={'text'} |                                         type={'text'} | ||||||
|                                         value={`sftp://${sftp.ip}:${sftp.port}`} |                                         value={`sftp://${formatIp(sftp.ip)}:${sftp.port}`} | ||||||
|                                         readOnly |                                         readOnly | ||||||
|                                     /> |                                     /> | ||||||
|                                 </CopyOnClick> |                                 </CopyOnClick> | ||||||
| @ -59,7 +60,7 @@ export default () => { | |||||||
|                                 <div css={tw`ml-4`}> |                                 <div css={tw`ml-4`}> | ||||||
|                                     <LinkButton |                                     <LinkButton | ||||||
|                                         isSecondary |                                         isSecondary | ||||||
|                                         href={`sftp://${username}.${id}@${sftp.ip}:${sftp.port}`} |                                         href={`sftp://${username}.${id}@${formatIp(sftp.ip)}:${sftp.port}`} | ||||||
|                                     > |                                     > | ||||||
|                                         Launch SFTP |                                         Launch SFTP | ||||||
|                                     </LinkButton> |                                     </LinkButton> | ||||||
|  | |||||||
| @ -63,3 +63,7 @@ export function encodePathSegments (path: string): string { | |||||||
| export function hashToPath (hash: string): string { | export function hashToPath (hash: string): string { | ||||||
|     return hash.length > 0 ? decodeURIComponent(hash.substr(1)) : '/'; |     return hash.length > 0 ? decodeURIComponent(hash.substr(1)) : '/'; | ||||||
| } | } | ||||||
|  | 
 | ||||||
|  | export function formatIp (ip: string): string { | ||||||
|  |     return /([a-f0-9:]+:+)+[a-f0-9]+/.test(ip) ? `[${ip}]` : ip; | ||||||
|  | } | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 Patrick R
						Patrick R