3proxy.cfg.3 28 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998
  1. .TH 3proxy.cfg "8" "January 2019" "3proxy 0.9" "Universal proxy server"
  2. .SH NAME
  3. .B 3proxy.cfg
  4. 3proxy configuration file
  5. .SH DESCRIPTION
  6. Common structure:
  7. .br
  8. Configuration file is a text file 3proxy reads configuration from. Each line
  9. of the file is a command executed immediately, as it was given from
  10. console. Sequence of commands is important. Configuration file as actually a
  11. script for 3proxy executable.
  12. Each line of the file is treated as a blank (space or tab) separated
  13. command line. Additional space characters are ignored.
  14. Think about 3proxy as "application level router" with console interface.
  15. .br
  16. Comments:
  17. .br
  18. Any string beginning with space character or \'#\' character is comment. It\'s
  19. ignored. <LF>s are ignored. <CR> is end of command.
  20. .br
  21. Quotation:
  22. .br
  23. Quotation character is " (double quote). Quotation must be used to quote
  24. spaces or another special characters. To use quotation character inside
  25. quotation character must be dubbed (BASIC convention). For example to use
  26. HELLO "WORLD" as an argument you should use it as "HELLO ""WORLD""".
  27. Good practice is to quote any argument you use.
  28. .br
  29. File inclusion:
  30. .br
  31. You can include file by using $FILENAME macro (replace FILENAME with a path
  32. to file, for example $/usr/local/etc/3proxy/conf.incl or
  33. $"c:\\\\Program Files\\3proxy\\include.cfg" Quotation is
  34. required in last example because path contains space character.
  35. For included file <CR> (end of line characters) is treated as space character
  36. (arguments delimiter instead of end of command delimiter).
  37. Thus, include files are only useful to store long signle-line commands
  38. (like userlist, network lists, etc).
  39. To use dollar sign somewhere in argument it must be quoted.
  40. Recursion is not allowed.
  41. .br
  42. Next commands start gateway services:
  43. .br
  44. .B proxy
  45. [options]
  46. .br
  47. .B socks
  48. [options]
  49. .br
  50. .B pop3p
  51. [options]
  52. .br
  53. .B ftppr
  54. [options]
  55. .br
  56. .B admin
  57. [options]
  58. .br
  59. .B dnspr
  60. [options]
  61. .br
  62. .B tcppm
  63. [options]
  64. <SRCPORT> <DSTADDR> <DSTPORT>
  65. .br
  66. .B udppm
  67. [options]
  68. <SRCPORT> <DSTADDR> <DSTPORT>
  69. .br
  70. Descriptions:
  71. .br
  72. .B proxy
  73. HTTP/HTTPS proxy (default port 3128)
  74. .br
  75. .B socks
  76. SOCKS 4/4.5/5 proxy (default port 1080)
  77. .br
  78. .B pop3p
  79. POP3 proxy (default port 110)
  80. .br
  81. .B ftppr
  82. FTP proxy (default port 21)
  83. .br
  84. .B admin
  85. Web interface (default port 80)
  86. .br
  87. .B dnspr
  88. caching DNS proxy (default port 53)
  89. .br
  90. .B tcppm
  91. TCP portmapper
  92. .br
  93. .B udppm
  94. UDP portmapper
  95. .br
  96. Options:
  97. .br
  98. .B -pNUMBER
  99. change default server port to NUMBER
  100. .br
  101. .B -n
  102. disable NTLM authentication (required if passwords are stored in Unix crypt format).
  103. .br
  104. .B -n1
  105. enable NTLMv1 authentication.
  106. .br
  107. .B -s
  108. (for admin) secure, allow only secure operations, currently only traffic counters
  109. view without ability to reset.
  110. .br
  111. (for dnspr) simple, do not use resolver and 3proxy cache, always use external DNS server.
  112. .br
  113. (for udppm) singlepacket, expect only one packet from both client and server
  114. .br
  115. .B -u
  116. Never ask for username/password
  117. .br
  118. .B -u2
  119. (for socks) require username/password in authentication methods
  120. .br
  121. .B -a
  122. (for proxy) anonymous proxy (no information about client reported)
  123. .br
  124. .B -a1
  125. (for proxy) anonymous proxy (random client information reported)
  126. .br
  127. .B -a2
  128. (for proxy) generate Via: and X-Forwared-For: instead of Forwarded:
  129. .br
  130. .B -6
  131. Only resolve IPv6 addresses. IPv4 addresses are packed in IPv6 in IPV6_V6ONLY compatible way.
  132. .br
  133. .B -4
  134. Only resolve IPv4 addresses
  135. .br
  136. .B -46
  137. Resolve IPv6 addresses if IPv4 address is not resolvable
  138. .br
  139. .B -64
  140. Resolve IPv4 addresses if IPv6 address is not resolvable
  141. .br
  142. .B -RHOST:port
  143. listen on given local HOST:port for incoming connections instead of making remote outgoing connection. Can be used with another 3proxy service running -r option for connect back functionality. Most commonly used with tcppm. HOST can be given as IP or hostname, useful in case of dynamic DNS.
  144. .br
  145. .B -rHOST:port
  146. connect to given remote HOST:port instead of listening local connection on -p or default port. Can be used with another 3proxy service running -R option for connect back functionality. Most commonly used with proxy or socks. HOST can be given as IP or hostname, useful in case of dynamic DNS.
  147. .br
  148. .B -ocOPTIONS, -osOPTIONS, -olOPTIONS, -orOPTIONS, -oROPTIONS
  149. options for proxy-to-client (oc), proxy-to-server (os), proxy listening (ol), connect back client (or), connect back listening (oR) sockets.
  150. Options like TCP_CORK, TCP_NODELAY, TCP_DEFER_ACCEPT, TCP_QUICKACK, TCP_TIMESTAMPS, USE_TCP_FASTOPEN, SO_REUSEADDR, SO_REUSEPORT, SO_PORT_SCALABILITY, SO_REUSE_UNICASTPORT, SO_KEEPALIVE, SO_DONTROUTE may be supported depending on OS.
  151. .br
  152. .B -DiINTERFACE, -DeINTERFACE
  153. bind internal interface / external inteface to given INTERFACE (e.g. eth0) if SO_BINDTODEVICE supported by system. You may need to run as root or to have CAP_NET_RAW capability in order to bind to interface, depending on system.
  154. .br
  155. Also, all options mentioned for
  156. .BR proxy (8)
  157. .BR socks (8)
  158. .BR pop3p (8)
  159. .BR tcppm (8)
  160. .BR udppm (8)
  161. .BR ftppr (8)
  162. are also supported.
  163. .br
  164. Portmapping services listen at SRCPORT and connect to DSTADDR:DSTPORT
  165. HTTP and SOCKS proxies are standard.
  166. .br
  167. POP3 proxy must be configured as POP3 server and requires username in the form of:
  168. pop3username@pop3server. If POP3 proxy access must be authenticated, you can
  169. specify username as proxy_username:proxy_password:POP3_username@pop3server
  170. .br
  171. DNS proxy resolves any types of records but only hostnames are cached. It
  172. requires nserver/nscache to be configured. If nserver is configured as TCP,
  173. redirections are applied on connection, so parent proxy may be used to resolve
  174. names to IP.
  175. .br
  176. FTP proxy can be used as FTP server in any FTP client or configured as FTP
  177. proxy on a client with FTP proxy support. Username format is one of
  178. .br
  179. FTPuser@FTPServer
  180. .br
  181. FTPuser:FTPpassword@FTPserver
  182. .br
  183. proxyuser:proxypassword:FTPuser:FTPpassword@FTPserver
  184. .br
  185. Please note, if you use FTP client interface for FTP proxy do not add FTPpassword and FTPServer to username, because FTP client does it for you. That is, if you use 3proxy with authentication use proxyuser:proxypassword:FTPuser as FTP username, otherwise do not change original FTP user name
  186. .br
  187. .B include
  188. <path>
  189. .br
  190. Include config file
  191. .br
  192. .B config
  193. <path>
  194. .br
  195. Path to configuration file to use on 3proxy restart or to save configuration.
  196. .br
  197. .B writable
  198. .br
  199. ReOpens configuration file for write access via Web interface,
  200. and rereads it. Usually should be first command on config file
  201. but in combination with config
  202. it can be used anywhere to open
  203. alternate config file. Think twice before using it.
  204. .br
  205. .B end
  206. .br
  207. End of configuration
  208. .br
  209. .B log
  210. [[@|&]logfile] [<LOGTYPE>]
  211. .br
  212. sets logfile for all gateways
  213. .br
  214. @ (for Unix) use syslog, filename is used as ident name
  215. .br
  216. & use ODBC, filename consists of comma-delimited datasource,username,password (username and password are optional)
  217. .br
  218. LOGTYPE is one of:
  219. .br
  220. M Monthly
  221. .br
  222. W Weekly (starting from Sunday)
  223. .br
  224. D Daily
  225. .br
  226. H Hourly
  227. .br
  228. if logfile is not specified logging goes to stdout. You can specify individual logging options for gateway by using -l
  229. option in gateway configuration.
  230. .br
  231. log command supports same format specifications for filename template
  232. as "logformat" (if filename contains \'%\' sign it\'s believed to be template).
  233. As with "logformat" filename must begin with \'L\' or \'G\' to specify Local or
  234. Grinwitch time zone for all time-based format specificators.
  235. .br
  236. .B rotate
  237. <n>
  238. how many archived log files to keep
  239. .br
  240. .B logformat
  241. <format>
  242. .br
  243. Format for log record. First symbol in format must be L (local time)
  244. or G (absolute Grinwitch time).
  245. It can be preceeded with -XXX+Y where XXX is list of characters to be
  246. filtered in user input (any non-printable characters are filtered too
  247. in this case) and Y is replacement character. For example, "-,%+ L" in
  248. the beginning of logformat means comma and percent are replaced
  249. with space and all time based elemnts are in local time zone.
  250. .br
  251. You can use:
  252. .br
  253. %y Year in 2 digit format
  254. .br
  255. %Y Year in 4 digit format
  256. .br
  257. %m Month number
  258. .br
  259. %o Month abbriviature
  260. .br
  261. %d Day
  262. .br
  263. %H Hour
  264. .br
  265. %M Minute
  266. .br
  267. %S Second
  268. .br
  269. %t Timstamp (in seconds since 01-Jan-1970)
  270. .br
  271. %. milliseconds
  272. .br
  273. %z timeZone (from Grinvitch)
  274. .br
  275. %D request duration (in milliseconds)
  276. .br
  277. %b average send rate per request (in Bytes per second) this speed is typically below connection speed shown by download manager.
  278. .br
  279. %B average receive rate per request (in Bytes per second) this speed is typically below connection speed shown by download manager.
  280. .br
  281. %U Username
  282. .br
  283. %N service Name
  284. .br
  285. %p service Port
  286. .br
  287. %E Error code
  288. .br
  289. %C Client IP
  290. .br
  291. %c Client port
  292. .br
  293. %R Remote IP
  294. .br
  295. %r Remote port
  296. .br
  297. %i Internal IP used to accept client connection
  298. .br
  299. %e External IP used to establish connection
  300. .br
  301. %Q Requested IP
  302. .br
  303. %q Requested port
  304. .br
  305. %n requested hostname
  306. .br
  307. %I bytes In
  308. .br
  309. %O bytes Out
  310. .br
  311. %h Hops (redirections) count
  312. .br
  313. %T service specific Text
  314. .br
  315. %N1-N2T (N1 and N2 are positive numbers) log only fields from N1 thorugh N2 of service specific text
  316. .br
  317. in the case of ODBC logging logformat specifies SQL statement, for exmample:
  318. .br
  319. logformat "-\'+_Linsert into log (l_date, l_user, l_service, l_in, l_out, l_descr) values (\'%d-%m-%Y %H:%M:%S\', \'%U\', \'%N\', %I, %O, \'%T\')"
  320. .br
  321. .B logdump
  322. <in_traffic_limit> <out_traffic_limit>
  323. .br
  324. Immediately creates additional log records if given amount of incoming/outgoing
  325. traffic is achieved for connection, without waiting for connection to finish.
  326. It may be useful to prevent information about long-lasting downloads on server
  327. shutdown.
  328. .br
  329. .B archiver
  330. <ext> <commandline>
  331. .br
  332. Archiver to use for log files. <ext> is file extension produced by
  333. archiver. Filename will be last argument to archiver, optionally you
  334. can use %A as produced archive name and %F as filename.
  335. .br
  336. .B timeouts
  337. <BYTE_SHORT> <BYTE_LONG> <STRING_SHORT> <STRING_LONG> <CONNECTION_SHORT> <CONNECTION_LONG> <DNS> <CHAIN> <CONNECT> <CONNECTBACK>
  338. .br
  339. Sets timeout values, defaults 1, 5, 30, 60, 180, 1800, 15, 60, 15, 5.
  340. .br
  341. BYTE_SHORT short timeout for single byte, is usually used for receiving single byte from stream.
  342. .br
  343. BYTE_LONG long timeout for single byte, is usually used for receiving first byte in frame (for example first byte in socks request).
  344. .br
  345. STRING_SHORT short timeout, for character string within stream (for example to wait between 2 HTTP headers)
  346. .br
  347. STRING_LONG long timeout, for first string in stream (for example to wait for HTTP request).
  348. .br
  349. CONNECTION_SHORT inactivity timeout for short connections (HTTP, POP3, etc).
  350. .br
  351. CONNECTION_LONG inactivity timeout for long connection (SOCKS, portmappers, etc).
  352. .br
  353. DNS timeout for DNS request before requesting next server
  354. .br
  355. CHAIN timeout for reading data from chained connection
  356. .br
  357. .B nserver
  358. <ipaddr>[:port][/tcp]
  359. .br
  360. Nameserver to use for name resolutions. If none specified
  361. or name server fails system routines for name resolution will be
  362. used. It\'s better to specify nserver because gethostbyname() may
  363. be thread unsafe. Optional port number may be specified.
  364. If optional /tcp is added to IP address, name resolution will be
  365. performed over TCP.
  366. .br
  367. .B nscache
  368. <cachesize>
  369. .B nscache6
  370. <cachesize>
  371. .br
  372. Cache <cachesize> records for name resolution (nscache for IPv4,
  373. nscache6 for IPv6). Cachesize usually should be large enougth
  374. (for example 65536).
  375. .br
  376. .B nsrecord
  377. <hostname> <hostaddr>
  378. .br
  379. Adds static record to nscache. nscache must be enabled. If 0.0.0.0
  380. is used as a hostaddr host will never resolve, it can be used to
  381. blacklist something or together with
  382. .B dialer
  383. command to set up UDL for dialing.
  384. .br
  385. .B fakeresolve
  386. .br
  387. All names are resolved to 127.0.0.2 address. Usefull if all requests are
  388. redirected to parent proxy with http, socks4+, connect+ or socks5+.
  389. .br
  390. .B dialer
  391. <progname>
  392. .br
  393. Execute progname if external name can\'t be resolved.
  394. Hint: if you use nscache, dialer may not work, because names will
  395. be resolved through cache. In this case you can use something like
  396. http://dial.right.now/ from browser to set up connection.
  397. .br
  398. .B internal
  399. <ipaddr>
  400. .br
  401. sets ip address of internal interface. This IP address will be used
  402. to bind gateways. Alternatively you can use -i option for individual
  403. gateways. Since 0.8 version, IPv6 address may be used.
  404. .br
  405. .B external
  406. <ipaddr>
  407. .br
  408. sets ip address of external interface. This IP address will be source
  409. address for all connections made by proxy. Alternatively you can use -e
  410. option to specify individual address for gateway. Since 0.8 version
  411. External or -e can be given twice: once with IPv4 and once with IPv6 address.
  412. .br
  413. .B maxconn
  414. <number>
  415. .br
  416. sets maximum number of simulationeous connections to each services
  417. started after this command. Default is 100.
  418. .br
  419. .B service
  420. .br
  421. (depricated). Indicates 3proxy to behave as Windows 95/98/NT/2000/XP
  422. service, no effect for Unix. Not required for 3proxy 0.6 and above. If
  423. you upgraded from previous version of 3proxy use --remove and --install
  424. to reinstall service.
  425. .br
  426. .B daemon
  427. .br
  428. Should be specified to close console. Do not use \'daemon\' with \'service\'.
  429. At least under FreeBSD \'daemon\' should preceed any proxy service
  430. and log commands to avoid sockets problem. Always place it in the beginning
  431. of the configuration file.
  432. .br
  433. .B auth
  434. <authtype> [...]
  435. .br
  436. Type of user authorization. Currently supported:
  437. .br
  438. none - no authentication or authorization required.
  439. .br
  440. Note: is auth is none any ip based limitation, redirection, etc will not work.
  441. This is default authentication type
  442. .br
  443. iponly - authentication by access control list with username ignored.
  444. Appropriate for most cases
  445. .br
  446. useronly - authentication by username without checking for any password with
  447. authorization by ACLs. Useful for e.g. SOCKSv4 proxy and icqpr (icqpr set UIN /
  448. AOL screen name as a username)
  449. .br
  450. dnsname - authentication by DNS hostnname with authorization by ACLs.
  451. DNS hostname is resolved via PTR (reverse) record and validated (resolved
  452. name must resolve to same IP address). It\'s recommended to use authcache by
  453. ip for this authentication.
  454. NB: there is no any password check, name may be spoofed.
  455. .br
  456. strong - username/password authentication required. It will work with
  457. SOCKSv5, FTP, POP3 and HTTP proxy.
  458. .br
  459. cache - cached authentication, may be used with \'authcache\'.
  460. .br
  461. Plugins may add additional authentication types.
  462. .br
  463. It\'s possible to use few authentication types in the same commands. E.g.
  464. .br
  465. auth iponly strong
  466. .br
  467. In this case \'strong\' authentication will be used only in case resource
  468. access can not be performed with \'iponly\' authentication, that is username is
  469. required in ACL. It\'s usefull to protect access to some resources with
  470. password allowing passwordless access to another resources, or to use
  471. IP-based authentication for dedicated laptops and request username/password for
  472. shared ones.
  473. .br
  474. .B authcache
  475. <cachtype> <cachtime>
  476. .br
  477. Cache authentication information to given amount of time (cachetime) in seconds.
  478. Cahtype is one of:
  479. .br
  480. ip - after successful authentication all connections during caching time
  481. from same IP are assigned to the same user, username is not requested.
  482. .br
  483. ip,user username is requested and all connections from the same IP are
  484. assigned to the same user without actual authentication.
  485. .br
  486. user - same as above, but IP is not checked.
  487. .br
  488. user,password - both username and password are checked against cached ones.
  489. .br
  490. Use auth type \'cache\' for cached authentication
  491. .br
  492. .B allow
  493. <userlist> <sourcelist> <targetlist> <targetportlist> <operationlist>
  494. <weekdayslist> <timeperiodslist>
  495. .br
  496. .B deny
  497. <userlist> <sourcelist> <targetlist> <targetportlist> <operationlist>
  498. <weekdayslist> <timeperiodslist>
  499. .br
  500. Access control entries. All lists are comma-separated, no spaces are
  501. allowed. Usernames are case sensitive (if used with authtype nbname
  502. username must be in uppercase). Source and target lists may contain
  503. IP addresses (W.X.Y.Z), ranges A.B.C.D - W.X.Y.Z (since 0.8) or CIDRs (W.X.Y.Z/L).
  504. Since 0.6, targetlist may also contain host names,
  505. instead of addresses. It\'s possible to use wildmask in
  506. the begginning and in the the end of hostname, e.g. *badsite.com or *badcontent*.
  507. Hostname is only checked if hostname presents in request.
  508. Targetportlist may contain ports (X) or port ranges lists (X-Y). For any field *
  509. sign means ANY. If access list is empty it\'s assumed to be
  510. .br
  511. allow *
  512. .br
  513. If access list is not empty last item in access list is assumed to be
  514. .br
  515. deny *
  516. .br
  517. You may want explicitly add deny * to the end of access list to prevent
  518. HTTP proxy from requesting user\'s password.
  519. Access lists are checked after user have requested any resource.
  520. If you want 3proxy to reject connections from specific addresses
  521. immediately without any conditions you should either bind proxy
  522. to appropriate interface only or to use ip filters.
  523. .br
  524. Operation is one of:
  525. .br
  526. CONNECT establish outgoing TCP connection
  527. .br
  528. BIND bind TCP port for listening
  529. .br
  530. UDPASSOC make UDP association
  531. .br
  532. ICMPASSOC make ICMP association (for future use)
  533. .br
  534. HTTP_GET HTTP GET request
  535. .br
  536. HTTP_PUT HTTP PUT request
  537. .br
  538. HTTP_POST HTTP POST request
  539. .br
  540. HTTP_HEAD HTTP HEAD request
  541. .br
  542. HTTP_CONNECT HTTP CONNECT request
  543. .br
  544. HTTP_OTHER over HTTP request
  545. .br
  546. HTTP matches any HTTP request except HTTP_CONNECT
  547. .br
  548. HTTPS same as HTTP_CONNECT
  549. .br
  550. FTP_GET FTP get request
  551. .br
  552. FTP_PUT FTP put request
  553. .br
  554. FTP_LIST FTP list request
  555. .br
  556. FTP_DATA FTP data connection. Note: FTP_DATA requires access to dynamic
  557. non-ptivileged (1024-65535) ports on remote side.
  558. .br
  559. FTP matches any FTP/FTP Data request
  560. .br
  561. ADMIN access to administration interface
  562. .br
  563. Weeksdays are week days numbers or periods, 0 or 7 means Sunday, 1 is Monday, 1-5 means Monday through Friday.
  564. .br
  565. Timeperiodlists is a list of time
  566. periods in HH:MM:SS-HH:MM:SS format. For example, 00:00:00-08:00:00,17:00:00-24:00:00 lists non-working hours.
  567. .br
  568. .B parent
  569. <weight> <type> <ip> <port> <username> <password>
  570. .br
  571. this command must follow "allow" rule. It extends last allow rule to
  572. build proxy chain. Proxies may be grouped. Proxy inside the
  573. group is selected randomly. If few groups are specified one proxy
  574. is randomly picked from each group and chain of proxies is created
  575. (that is second proxy connected through first one and so on).
  576. Weight is used to group proxies. Weigt is a number between 1 and 1000.
  577. Weights are summed and proxies are grouped together untill weight of
  578. group is 1000. That is:
  579. .br
  580. allow *
  581. .br
  582. parent 500 socks5 192.168.10.1 1080
  583. .br
  584. parent 500 connect 192.168.10.1 3128
  585. .br
  586. makes 3proxy to randomly choose between 2 proxies for all outgoing
  587. connections. These 2 proxies form 1 group (summarized weight is 1000).
  588. .br
  589. allow * * * 80
  590. .br
  591. parent 1000 socks5 192.168.10.1 1080
  592. .br
  593. parent 1000 connect 192.168.20.1 3128
  594. .br
  595. parent 300 socks4 192.168.30.1 1080
  596. .br
  597. parent 700 socks5 192.168.40.1 1080
  598. .br
  599. creates chain of 3 proxies: 192.168.10.1, 192.168.20.1 and third
  600. is (192.168.30.1 with probability of 0.3 or 192.168.40.1
  601. with probability of 0.7) for outgoing web connections.
  602. .br
  603. type is one of:
  604. .br
  605. tcp simply redirect connection. TCP is always last in chain.
  606. .br
  607. http redirect to HTTP proxy. HTTP is always last chain.
  608. .br
  609. pop3 redirect to POP3 proxy (only local redirection is supported, can not be
  610. used for chaining)
  611. .br
  612. ftp redirect to FTP proxy (only local redirection is supported, can not be
  613. used for chaining)
  614. .br
  615. connect parent is HTTP CONNECT method proxy
  616. .br
  617. connect+ parent is HTTP CONNECT proxy with name resolution
  618. .br
  619. socks4 parent is SOCKSv4 proxy
  620. .br
  621. socks4+ parent is SOCKSv4 proxy with name resolution (SOCKSv4a)
  622. .br
  623. socks5 parent is SOCKSv5 proxy
  624. .br
  625. socks5+ parent is SOCKSv5 proxy with name resolution
  626. .br
  627. socks4b parent is SOCKS4b (broken SOCKSv4 implementation with shortened
  628. server reply. I never saw this kind ofservers byt they say there are).
  629. Normally you should not use this option. Do not mess this option with
  630. SOCKSv4a (socks4+).
  631. .br
  632. socks5b parent is SOCKS5b (broken SOCKSv5 implementation with shortened
  633. server reply. I think you will never find it useful). Never use this option
  634. unless you know exactly you need it.
  635. .br
  636. admin redirect request to local \'admin\' service (with -s parameter).
  637. .br
  638. Use "+" proxy only with "fakeresolve" option
  639. .br
  640. IP and port are ip addres and port of parent proxy server.
  641. If IP is zero, ip is taken from original request, only port is changed.
  642. If port is zero, it\'s taken from original request, only IP is changed.
  643. If both IP and port are zero - it\'s a special case of local redirection,
  644. it works only with
  645. .B socks
  646. proxy. In case of local redirection request is redirected to different service,
  647. .B ftp
  648. locally redirects to
  649. .B ftppr
  650. .B pop3
  651. locally redirects to
  652. .B pop3p
  653. .B http
  654. locally redurects to
  655. .B proxy
  656. .B admin
  657. locally redirects to admin -s service.
  658. .br
  659. Main purpose of local redirections is to have requested resource
  660. (URL or POP3 username) logged and protocol-specific filters to be applied.
  661. In case of local redirection ACLs are revied twice: first, by SOCKS proxy up to \'parent\'
  662. command and then with gateway service connection is
  663. redirected (HTTP, FTP or POP3) after \'parent\' command. It means,
  664. additional \'allow\' command is required for redirected requests, for
  665. example:
  666. .br
  667. allow * * * 80
  668. .br
  669. parent 1000 http 0.0.0.0 0
  670. .br
  671. allow * * * 80 HTTP_GET,HTTP_POST
  672. .br
  673. socks
  674. .br
  675. redirects all SOCKS requests with target port 80 to local HTTP proxy,
  676. local HTTP proxy parses requests and allows only GET and POST requests.
  677. .br
  678. parent 1000 http 1.2.3.4 0
  679. .br
  680. Changes external address for given connection to 1.2.3.4 (an equivalent to -e1.2.3.4)
  681. .br
  682. Optional username and password are used to authenticate on parent
  683. proxy. Username of \'*\' means username must be supplied by user.
  684. .br
  685. .B nolog
  686. <n>
  687. .br
  688. extends last allow or deny command to prevent logging, e.g.
  689. .br
  690. allow * * 192.168.1.1
  691. .br
  692. nolog
  693. .br
  694. .B weight
  695. <n>
  696. .br
  697. extends last allow or deny command to set weight for this request
  698. .br
  699. allow * * 192.168.1.1
  700. .br
  701. weight 100
  702. .br
  703. Weight may be used for different purposes.
  704. .br
  705. .B force
  706. .br
  707. .B noforce
  708. .br
  709. If force is specified for service, configuration reload will require all current
  710. sessions of this service to be re-authenticated. If ACL is changed or user account
  711. is removed, old connections which do not match current are closed.
  712. noforce allows to keep previously authenticated connections.
  713. .br
  714. .B bandlimin
  715. <rate> <userlist> <sourcelist> <targetlist> <targetportlist> <operationlist>
  716. .br
  717. .B nobandlimin
  718. <userlist> <sourcelist> <targetlist> <targetportlist> <operationlist>
  719. .br
  720. .B bandlimout
  721. <rate> <userlist> <sourcelist> <targetlist> <targetportlist> <operationlist>
  722. .br
  723. .B nobandlimout
  724. <userlist> <sourcelist> <targetlist> <targetportlist> <operationlist>
  725. .br
  726. bandlim sets bandwith limitation filter to <rate> bps (bits per second)
  727. If you want to specife bytes per second - multiply your value to 8.
  728. bandlim rules act in a same manner as allow/deny rules except
  729. one thing: bandwidth limiting is applied to all services, not to some
  730. specific service.
  731. bandlimin and nobandlimin applies to incoming traffic
  732. bandlimout and nobandlimout applies to outgoing traffic
  733. If tou want to ratelimit your clients with IPs 192.168.10.16/30 (4
  734. addresses) to 57600 bps you have to specify 4 rules like
  735. .br
  736. bandlimin 57600 * 192.168.10.16
  737. .br
  738. bandlimin 57600 * 192.168.10.17
  739. .br
  740. bandlimin 57600 * 192.168.10.18
  741. .br
  742. bandlimin 57600 * 192.168.10.19
  743. .br
  744. and every of you clients will have 56K channel. If you specify
  745. .br
  746. bandlimin 57600 * 192.168.10.16/30
  747. .br
  748. you will have 56K channel shared between all clients.
  749. if you want, for example, to limit all speed ecept access to POP3 you can use
  750. .br
  751. nobandlimin * * * 110
  752. .br
  753. before the rest of bandlim rules.
  754. .br
  755. .B connlim
  756. <rate> <period> <userlist> <sourcelist> <targetlist> <targetportlist> <operationlist>
  757. .br
  758. .B noconnlim
  759. <userlist> <sourcelist> <targetlist> <targetportlist> <operationlist>
  760. .br
  761. connlim sets connections rate limit per time period for traffic
  762. pattern controlled by ACL. Period is in seconds. If period is 0,
  763. connlim limits a number of parallel connections.
  764. .br
  765. connlim 100 60 * 127.0.0.1
  766. .br
  767. allows 100 connections per minute for 127.0.0.1.
  768. .br
  769. connlim 20 0 * 127.0.0.1
  770. .br
  771. allows 20 simulationeous connections for 127.0.0.1.
  772. .br
  773. Like with bandlimin, if individual limit is required per client, separate
  774. rule mustbe added for every client. Like with nobanlimin, noconnlim adds an
  775. exception.
  776. .br
  777. .B counter
  778. <filename> <reporttype> <repotname>
  779. .br
  780. .B countin
  781. <number> <type> <limit> <userlist> <sourcelist> <targetlist> <targetportlist> <operationlist>
  782. .br
  783. .B nocountin
  784. <userlist> <sourcelist> <targetlist> <targetportlist> <operationlist>
  785. .br
  786. .B countout
  787. <number> <type> <limit> <userlist> <sourcelist> <targetlist> <targetportlist> <operationlist>
  788. .br
  789. .B nocountout
  790. <userlist> <sourcelist> <targetlist> <targetportlist> <operationlist>
  791. .br
  792. counter, countin, nocountin, countout, noucountout commands are
  793. used to set traffic limit
  794. in MB for period of time (day, week or month). Filename is a path
  795. to a special file where traffic information is permanently stored.
  796. number is sequential number of record in this file. If number is 0
  797. no traffic information on this counter is saved in file (that is
  798. if proxy restarted all information is loosed) overwise it should be
  799. unique sequential number.
  800. Type specifies a type of counter. Type is one of:
  801. .br
  802. H - counter is resetted hourly
  803. .br
  804. D - counter is resetted daily
  805. .br
  806. W - counter is resetted weekly
  807. .br
  808. M - counter is resetted monthely
  809. .br
  810. reporttype/repotname may be used to generate traffic reports.
  811. Reporttype is one of D,W,M,H(hourly) and repotname specifies filename
  812. template for reports. Report is text file with counter values in
  813. format:
  814. .br
  815. <COUNTERNUMBER> <TRAF>
  816. .br
  817. The rest of parameters is identical to bandlim/nobandlim.
  818. .br
  819. .B users
  820. username[:pwtype:password] ...
  821. .br
  822. pwtype is one of:
  823. .br
  824. none (empty) - use system authentication
  825. .br
  826. CL - password is cleartext
  827. .br
  828. CR - password is crypt-style password
  829. .br
  830. NT - password is NT password (in hex)
  831. .br
  832. example:
  833. .br
  834. users test1:CL:password1 "test2:CR:$1$lFDGlder$pLRb4cU2D7GAT58YQvY49."
  835. .br
  836. users test3:NT:BD7DFBF29A93F93C63CB84790DA00E63
  837. .br
  838. Note: double quotes are requiered because password contains $ sign.
  839. .br
  840. .B flush
  841. .br
  842. empty active access list. Access list must be flushed avery time you creating
  843. new access list for new service. For example:
  844. .br
  845. allow *
  846. .br
  847. pop3p
  848. .br
  849. flush
  850. .br
  851. allow * 192.168.1.0/24
  852. .br
  853. socks
  854. .br
  855. sets different ACLs for
  856. .B pop3p
  857. and
  858. .B socks
  859. .br
  860. .B system
  861. <command>
  862. .br
  863. execute system command
  864. .br
  865. .B pidfile
  866. <filename>
  867. .br
  868. write pid of current process to file. It can be used to manipulate
  869. 3proxy with signals under Unix. Currently next signals are available:
  870. .br
  871. .B monitor
  872. <filename>
  873. .br
  874. If file monitored changes in modification time or size, 3proxy reloads
  875. configuration within one minute. Any number of files may be monitored.
  876. .br
  877. .B setuid
  878. <uid>
  879. .br
  880. calls setuid(uid), uid can be numeric or since 0.9 username. Unix only. Warning: under some Linux
  881. kernels setuid() works for current thread only. It makes it impossible to suid
  882. for all threads.
  883. .br
  884. .B setgid
  885. <gid>
  886. .br
  887. calls setgid(gid), gid can be numeric or since 0.9 groupname. Unix only.
  888. .br
  889. .B chroot
  890. <path> [<uid>] [<gid>]
  891. .br
  892. calls chroot(path) and sets gid/uid. Unix only. uid/gid supported since 0.9, can be numeric or username/groupname
  893. .br
  894. .B stacksize
  895. <value_to_add_to_default_stack_size>
  896. .br
  897. Change default size for threads stack. May be required in some situation,
  898. e.g. with non-default plugins, on on some platforms (some FreeBSD version
  899. may require adjusting stack size due to invalid defined value in system
  900. header files, this value is also oftent reqruied to be changed for ODBC and
  901. PAM support on Linux. If you experience 3proxy
  902. crash on request processing, try to set some positive value. You may start with
  903. stacksize 65536
  904. and then find the minimal value for service to work. If you experience
  905. memory shortage, you can try to experiment with negative values.
  906. .SH PLUGINS
  907. .br
  908. .B plugin
  909. <path_to_shared_library> <function_to_call> [<arg1> ...]
  910. .br
  911. Loads specified library and calls given export function with given arguments,
  912. as
  913. .br
  914. int functions_to_call(struct pluginlink * pl, int argc, char * argv[]);
  915. .br
  916. function_to_call must return 0 in case of success, value > 0 to indicate error.
  917. .br
  918. .B filtermaxsize
  919. <max_size_of_data_to_filter>
  920. .br
  921. If Content-length (or another data length) is greater than given value, no
  922. data filtering will be performed thorugh filtering plugins to avoid data
  923. corruption and/or Content-Length chaging. Default is 1MB (1048576).
  924. .SH BUGS
  925. Report all bugs to
  926. .BR 3proxy@3proxy.ru
  927. .SH SEE ALSO
  928. 3proxy(8), proxy(8), ftppr(8), socks(8), pop3p(8), tcppm(8), udppm(8), syslogd(8),
  929. .br
  930. https://3proxy.org/
  931. .SH TRIVIA
  932. 3APA3A is pronounced as \`\`zaraza\'\'.
  933. .SH AUTHORS
  934. 3proxy is designed by Vladimir 3APA3A Dubrovin
  935. .RI ( 3proxy@3proxy.ru )