1 #*************************************************************************** 2 # _ _ ____ _ 3 # Project ___| | | | _ \| | 4 # / __| | | | |_) | | 5 # | (__| |_| | _ <| |___ 6 # \___|\___/|_| \_\_____| 7 # 8 # Copyright (C) 1998 - 2016, Daniel Stenberg, <daniel (at] haxx.se>, et al. 9 # 10 # This software is licensed as described in the file COPYING, which 11 # you should have received as part of this distribution. The terms 12 # are also available at https://curl.haxx.se/docs/copyright.html. 13 # 14 # You may opt to use, copy, modify, merge, publish, distribute and/or sell 15 # copies of the Software, and permit persons to whom the Software is 16 # furnished to do so, under the terms of the COPYING file. 17 # 18 # This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY 19 # KIND, either express or implied. 20 # 21 #*************************************************************************** 22 23 package serverhelp; 24 25 use strict; 26 use warnings; 27 use Exporter; 28 29 30 #*************************************************************************** 31 # Global symbols allowed without explicit package name 32 # 33 use vars qw( 34 @ISA 35 @EXPORT_OK 36 ); 37 38 39 #*************************************************************************** 40 # Inherit Exporter's capabilities 41 # 42 @ISA = qw(Exporter); 43 44 45 #*************************************************************************** 46 # Global symbols this module will export upon request 47 # 48 @EXPORT_OK = qw( 49 serverfactors 50 servername_id 51 servername_str 52 servername_canon 53 server_pidfilename 54 server_logfilename 55 server_cmdfilename 56 server_inputfilename 57 server_outputfilename 58 mainsockf_pidfilename 59 mainsockf_logfilename 60 datasockf_pidfilename 61 datasockf_logfilename 62 ); 63 64 65 #*************************************************************************** 66 # Just for convenience, test harness uses 'https' and 'httptls' literals as 67 # values for 'proto' variable in order to differentiate different servers. 68 # 'https' literal is used for stunnel based https test servers, and 'httptls' 69 # is used for non-stunnel https test servers. 70 71 72 #*************************************************************************** 73 # Return server characterization factors given a server id string. 74 # 75 sub serverfactors { 76 my $server = $_[0]; 77 my $proto; 78 my $ipvnum; 79 my $idnum; 80 81 if($server =~ 82 /^((ftp|http|imap|pop3|smtp|http-pipe)s?)(\d*)(-ipv6|)$/) { 83 $proto = $1; 84 $idnum = ($3 && ($3 > 1)) ? $3 : 1; 85 $ipvnum = ($4 && ($4 =~ /6$/)) ? 6 : 4; 86 } 87 elsif($server =~ 88 /^(tftp|sftp|socks|ssh|rtsp|gopher|httptls)(\d*)(-ipv6|)$/) { 89 $proto = $1; 90 $idnum = ($2 && ($2 > 1)) ? $2 : 1; 91 $ipvnum = ($3 && ($3 =~ /6$/)) ? 6 : 4; 92 } 93 else { 94 die "invalid server id: '$server'" 95 } 96 return($proto, $ipvnum, $idnum); 97 } 98 99 100 #*************************************************************************** 101 # Return server name string formatted for presentation purposes 102 # 103 sub servername_str { 104 my ($proto, $ipver, $idnum) = @_; 105 106 $proto = uc($proto) if($proto); 107 die "unsupported protocol: '$proto'" unless($proto && 108 ($proto =~ /^(((FTP|HTTP|HTTP\/2|IMAP|POP3|SMTP|HTTP-PIPE)S?)|(TFTP|SFTP|SOCKS|SSH|RTSP|GOPHER|HTTPTLS|DICT|SMB|SMBS|TELNET))$/)); 109 110 $ipver = (not $ipver) ? 'ipv4' : lc($ipver); 111 die "unsupported IP version: '$ipver'" unless($ipver && 112 ($ipver =~ /^(4|6|ipv4|ipv6|-ipv4|-ipv6|unix)$/)); 113 $ipver = ($ipver =~ /6$/) ? '-IPv6' : (($ipver =~ /unix$/) ? '-unix' : ''); 114 115 $idnum = 1 if(not $idnum); 116 die "unsupported ID number: '$idnum'" unless($idnum && 117 ($idnum =~ /^(\d+)$/)); 118 $idnum = '' unless($idnum > 1); 119 120 return "${proto}${idnum}${ipver}"; 121 } 122 123 124 #*************************************************************************** 125 # Return server name string formatted for identification purposes 126 # 127 sub servername_id { 128 my ($proto, $ipver, $idnum) = @_; 129 return lc(servername_str($proto, $ipver, $idnum)); 130 } 131 132 133 #*************************************************************************** 134 # Return server name string formatted for file name purposes 135 # 136 sub servername_canon { 137 my ($proto, $ipver, $idnum) = @_; 138 my $string = lc(servername_str($proto, $ipver, $idnum)); 139 $string =~ tr/-/_/; 140 $string =~ s/\//_v/; 141 return $string; 142 } 143 144 145 #*************************************************************************** 146 # Return file name for server pid file. 147 # 148 sub server_pidfilename { 149 my ($proto, $ipver, $idnum) = @_; 150 my $trailer = '_server.pid'; 151 return '.'. servername_canon($proto, $ipver, $idnum) ."$trailer"; 152 } 153 154 155 #*************************************************************************** 156 # Return file name for server log file. 157 # 158 sub server_logfilename { 159 my ($logdir, $proto, $ipver, $idnum) = @_; 160 my $trailer = '_server.log'; 161 $trailer = '_stunnel.log' if(lc($proto) =~ /^(ftp|http|imap|pop3|smtp)s$/); 162 return "${logdir}/". servername_canon($proto, $ipver, $idnum) ."$trailer"; 163 } 164 165 166 #*************************************************************************** 167 # Return file name for server commands file. 168 # 169 sub server_cmdfilename { 170 my ($logdir, $proto, $ipver, $idnum) = @_; 171 my $trailer = '_server.cmd'; 172 return "${logdir}/". servername_canon($proto, $ipver, $idnum) ."$trailer"; 173 } 174 175 176 #*************************************************************************** 177 # Return file name for server input file. 178 # 179 sub server_inputfilename { 180 my ($logdir, $proto, $ipver, $idnum) = @_; 181 my $trailer = '_server.input'; 182 return "${logdir}/". servername_canon($proto, $ipver, $idnum) ."$trailer"; 183 } 184 185 186 #*************************************************************************** 187 # Return file name for server output file. 188 # 189 sub server_outputfilename { 190 my ($logdir, $proto, $ipver, $idnum) = @_; 191 my $trailer = '_server.output'; 192 return "${logdir}/". servername_canon($proto, $ipver, $idnum) ."$trailer"; 193 } 194 195 196 #*************************************************************************** 197 # Return file name for main or primary sockfilter pid file. 198 # 199 sub mainsockf_pidfilename { 200 my ($proto, $ipver, $idnum) = @_; 201 die "unsupported protocol: '$proto'" unless($proto && 202 (lc($proto) =~ /^(ftp|imap|pop3|smtp)s?$/)); 203 my $trailer = (lc($proto) =~ /^ftps?$/) ? '_sockctrl.pid':'_sockfilt.pid'; 204 return '.'. servername_canon($proto, $ipver, $idnum) ."$trailer"; 205 } 206 207 208 #*************************************************************************** 209 # Return file name for main or primary sockfilter log file. 210 # 211 sub mainsockf_logfilename { 212 my ($logdir, $proto, $ipver, $idnum) = @_; 213 die "unsupported protocol: '$proto'" unless($proto && 214 (lc($proto) =~ /^(ftp|imap|pop3|smtp)s?$/)); 215 my $trailer = (lc($proto) =~ /^ftps?$/) ? '_sockctrl.log':'_sockfilt.log'; 216 return "${logdir}/". servername_canon($proto, $ipver, $idnum) ."$trailer"; 217 } 218 219 220 #*************************************************************************** 221 # Return file name for data or secondary sockfilter pid file. 222 # 223 sub datasockf_pidfilename { 224 my ($proto, $ipver, $idnum) = @_; 225 die "unsupported protocol: '$proto'" unless($proto && 226 (lc($proto) =~ /^ftps?$/)); 227 my $trailer = '_sockdata.pid'; 228 return '.'. servername_canon($proto, $ipver, $idnum) ."$trailer"; 229 } 230 231 232 #*************************************************************************** 233 # Return file name for data or secondary sockfilter log file. 234 # 235 sub datasockf_logfilename { 236 my ($logdir, $proto, $ipver, $idnum) = @_; 237 die "unsupported protocol: '$proto'" unless($proto && 238 (lc($proto) =~ /^ftps?$/)); 239 my $trailer = '_sockdata.log'; 240 return "${logdir}/". servername_canon($proto, $ipver, $idnum) ."$trailer"; 241 } 242 243 244 #*************************************************************************** 245 # End of library 246 1; 247 248