summaryrefslogtreecommitdiffhomepage
path: root/src
AgeCommit message (Collapse)Author
2003-02-26(main): Removed duplicate code calling the filter_destroy() function.Robert James Kaes
Once is enough. [Detected by John M Wright]
2003-01-28# (connect_to_upstream): Improved the preprocessor directives to makeRobert James Kaes
sure the function would compile cleanly regardless of how the directive was set.
2003-01-27# Style clean up.Robert James Kaes
2003-01-27(display_usage): Removed the output line mentioning that regularRobert James Kaes
expression support was included. It will be there always.
2003-01-27(connect_to_upstream): Reorganized the preprocessor directives to makeRobert James Kaes
sure the function's symbol name is stored, even if upstream was not compiled it. This should keep some compilers from reporting errors.
2003-01-27Added support for conditionally using case sensitive filtering files.Robert James Kaes
Code changes from James E. Flemer.
2003-01-27(process_client_headers): Fixed inverted anonymous header logic. FixRobert James Kaes
comes from the FreeBSD port through James E. Flemer.
2002-12-04(strip_username_password): New function to remove anyRobert James Kaes
username/password part from the host URI. (extract_http_url), (extract_ssl_url): Use the new strip_username_password function to remove any non-host information from the URI.
2002-12-04Removed the "bool_t" type since it conflicts with the newer C standards.Robert James Kaes
The type was just replaced by "unsigned int" types.
2002-11-29(extract_http_url): Removed the leading "http://" from all the tests,Robert James Kaes
since it's skipped by the caller before the URL is passed to this function. (process_request): Include code to handle proxy FTP requests as well. This also lead to a bit of a cleanup in the calling conventions of extract_http_url function. tinyproxy can handle both types of resources by skipping the leading :// part.
2002-11-26Included code to disable the sending of the Via header. This is nowRobert James Kaes
controlled by the ViaHeader configure directive.
2002-11-21(child_main): Cleaned up the notice string to be more clear why aRobert James Kaes
child is being closed.
2002-11-21(main): Check to see if the PID file was created successfully, and ifRobert James Kaes
not report this to the user and close the program.
2002-11-21# Changed the return type for pidfile_create() to int from void.Robert James Kaes
2002-11-21(create_file_safely): Rather than exiting the program if there is anRobert James Kaes
error, a negative "error code" is returned to the program. The various callers then need to decide what to do. (pidfile_create): Returns an error status depending on whether the PID file was created successfully.
2002-11-13(relay_connection): Shutdown the client socket for writing once allRobert James Kaes
the data has been sent.
2002-11-13(destroy_conn): Added code to log any error messages when the socketsRobert James Kaes
are closed.
2002-11-03Removed all the code supporting the TCP tunnelling feature ofRobert James Kaes
tinyproxy. There is really no need for this code, since there are perfectly good programs out there (like rinetd) which are designed for TCP tunnelling. tinyproxy should be a good HTTP proxy, nothing more, and nothing less; therefore, the tunnelling code is gone.
2002-10-17(relay_connection): Ivan pointed out a bug with the code to send anyRobert James Kaes
remaining data to the server when the connections are being closed. It was a one line fix.
2002-10-03Fixed up the storing and sending of the internal tinyproxy logs priorRobert James Kaes
to when the log file is created. Also, the log file is created with the proper owner permissions.
2002-10-03#Style formatting change.Robert James Kaes
2002-10-03The internal log structure now uses a vector rather than a hash. ThisRobert James Kaes
change was required to actually display all the logs in the correct order. Also, all log lines are stored internally while tinyproxy is starting. At the appropriate point all the logs are written to the log file.
2002-10-03Filtering is now case insensitive.Robert James Kaes
2002-10-03#(makedaemon): Commented out the closing of the standard fileRobert James Kaes
descriptors since we need them to display error messages.
2002-10-03(child_main): Check to make sure memory could be allocated to handleRobert James Kaes
the child request. (child_main_loop): Added a call to truncate_log_file() when the log file is to be rotated.
2002-07-12(main): Fixed up a bug reported by Oswald Buddenha where the log file was ↵Robert James Kaes
being initially created with the initial user's permissions, which is obviously a problem if tinyproxy is not running as the initial user. This is now fixed by delaying the creation of the log file until _after_ tinyproxy has been switched to the user it will run as. Confused yet?
2002-07-09(create_file_safely):Robert James Kaes
(pidfile_create): Changed all the error logging to write to standard error and then exit the program. This will prevent segmentation fault problems from occurring because the log file could not be created properly.
2002-07-09(malloc_shared_memory): Changed the static character array to include the ↵Robert James Kaes
".XXXXXX" string already. This saves one system call when creating a temporary file name.
2002-06-27(child_make): Reset the various signals to the default signal handler so ↵Robert James Kaes
that the children can be properly destroyed.
2002-06-15(log_message): Changed the code so that the log is opened, written, and ↵Robert James Kaes
closed whenever a message is submitted. This allows the log file to be moved away, for example a rotating the log, and yet still have the information written to the correct file name by all the children.
2002-06-15Renamed the "log_rotation_request" boolean to "received_sighup".Robert James Kaes
(main): Removed the log file creation code because it has been moved into the log.c file. Also, removed the explicit fclose() for the log file since it will be close when the program has exited.
2002-06-15(child_main_loop): Moved the filter re-initiation code into the loop. This ↵Robert James Kaes
code is activated whenever the SIGHUP signal is received.
2002-06-15Removed the "logf" FILE structure from the config structure, and also ↵Robert James Kaes
renamed the "log_rotation_request" boolean to "received_sighup".
2002-06-15Removed the rotate_log_files() function since I'm moving to an Apache style ↵Robert James Kaes
where the _user_ needs to move the log file themselves, and tinyproxy will continue to write to the original name. This allows more flexibility for users to determine their own log rotation scheme.
2002-06-07Added myself to the copyright since I've made a bunch of changes to this file.Robert James Kaes
2002-06-07Added code to handle the "FilterDefaultDeny" directive. The ↵Robert James Kaes
filter_set_default_policy() function is used to select the default policy (either default allow or default deny) for the filtering code. Also, the two filtering functions now support the policy code.
2002-06-07Added the "FilterDefaultDeny" directive to allow the user to select whether ↵Robert James Kaes
the default policy of the filter is to allow everything which isn't denied, or to deny everything which isn't allowed.
2002-06-06A bunch of changes from Petr Lampa that add transparent proxy support to ↵Robert James Kaes
tinyproxy. The additional code is in process_request(), but Petr also had to change around some of the other functions (like process_client_headers and handle_connection.) Note: Right now this code has not been tested, but it is believed to work. To enable run ./configure --enable-transparent-proxy
2002-06-06(filter_domain): Removed code which stripped of a port number from the host ↵Robert James Kaes
name. The "host" variable will _always_ be just the name by the time filter_domain() is called.
2002-06-06(display_usage): Added a message indicating whether transparent proxy ↵Robert James Kaes
support has been compiled in.
2002-06-06Added a warning message to the Bind directive stating that it will be ↵Robert James Kaes
ignored if "transparent proxy" has been compiled into tinyproxy.
2002-06-06(send_stored_logs): Actually included the code to output the stored logs. ↵Robert James Kaes
Plus, there was a bug with how I was calling the hashmap_is_end() function. This has now been fixed.
2002-06-05(child_main): Added a DEBUG call to let me know which process has accepted a ↵Robert James Kaes
connection. This is needed for debugging using "gdb".
2002-06-05(malloc_shared_memory): Removed the assert() call for shared_file since it's ↵Robert James Kaes
now a static variable.
2002-06-05(acl_string_processing): Moved the string processing code out of check_acl() ↵Robert James Kaes
and into it's own function because it now does two (2) tests. If the ACL string is a complete host name, in other words doesn't start with a period, than a reverse DNS look-up is done on the host name and compared to the IP address of the client; otherwise, the normal text string comparison is done. (check_acl): Moved the string text out of the function and removed some logging code by jumping to the "Deny" code at the end of the function.
2002-05-31Added a boolean "truncate_file" flag for the create_file_safely() function.Robert James Kaes
2002-05-31(create_file_safely): Added the "truncate_file" boolean flag. This is ↵Robert James Kaes
needed since I use this function for both the log file and the pid file, and they behave differently when tinyproxy is started. (pidfile_create): Call create_file_safely() with a TRUE "truncate_file" flag so that the file is emptied whenever the pid file is needed.
2002-05-31The log file is now opened in "append" mode so that you can restart ↵Robert James Kaes
tinyproxy without losing the log file.
2002-05-31(process_server_headers): Since we're stripping off the carriage return and ↵Robert James Kaes
newline, we need to add them back on when sending the response header to the client.
2002-05-31(getpeer_information): Fixed a problem retrieving the FQDN of a host because ↵Robert James Kaes
I was passing in an incorrect parameter to gethostbyaddr(). D'oh.