Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/weppos/apachelogregex
Ruby parser for Apache log files based on regular expressions.
https://github.com/weppos/apachelogregex
Last synced: about 1 month ago
JSON representation
Ruby parser for Apache log files based on regular expressions.
- Host: GitHub
- URL: https://github.com/weppos/apachelogregex
- Owner: weppos
- License: other
- Created: 2008-08-17T19:08:01.000Z (over 16 years ago)
- Default Branch: master
- Last Pushed: 2009-12-19T11:28:25.000Z (about 15 years ago)
- Last Synced: 2025-01-07T03:40:29.704Z (about 2 months ago)
- Language: Ruby
- Homepage: https://simonecarletti.com/apachelogregex
- Size: 342 KB
- Stars: 54
- Watchers: 5
- Forks: 6
- Open Issues: 4
-
Metadata Files:
- Readme: README.rdoc
- Changelog: CHANGELOG.rdoc
- License: LICENSE.rdoc
Awesome Lists containing this project
README
= Apache Log Regex
Apache Log Regex is a Ruby port of Peter Hickman's Apache::LogRegex 1.4 Perl module,
available at http://cpan.uwinnipeg.ca/~peterhi/Apache-LogRegex.
It provides functionalities to parse a line from an Apache log file into a hash.== Dependencies
* Ruby >= 1.8.6 (not tested with previous versions)
ApacheLogRegex is compatible with Ruby 1.9.1.
== Overview
Apache Log Regex is designed to be a simple class to parse Apache log files.
It takes an Apache logging format and generates a regular expression which is used to parse a line from a log file and returns a Hash with keys corresponding to the fields defined in the log format.
The log format should match the one defined in your Apache configuration file with the LogFormat directive.== Example Usage
The following one is the most simple example usage.
It tries to parse the `access.log` file and echoes each parsed line.format = '%h %l %u %t \"%r\" %>s %b \"%{Referer}i\" \"%{User-Agent}i\"'
parser = ApacheLogRegex.new(format)
File.foreach('/var/apache/access.log') do |line|
parser.parse(line)
# {"%r"=>"GET /blog/index.xml HTTP/1.1", "%h"=>"87.18.183.252", ... }
endMore often, you might want to collect parsed lines and use them later in your program.
The following example iterates all log lines, parses them and returns an array of Hash with the results.format = '%h %l %u %t \"%r\" %>s %b \"%{Referer}i\" \"%{User-Agent}i\"'
parser = ApacheLogRegex.new(format)File.readlines('/var/apache/access.log').collect do |line|
parser.parse(line)
# {"%r"=>"GET /blog/index.xml HTTP/1.1", "%h"=>"87.18.183.252", ... }
endIf you want more control over the parser you can use the parse! method.
It raises a ParseError if given line doesn't match the log format.common_log_format = '%h %l %u %t \"%r\" %>s %b'
parser = ApacheLogRegex.new(common_log_format)
# No exception
parser.parse(line) # => nil
# Raises an exception
parser.parse!(line) # => ParseError== Acknowledgments
This library is essentially a Ruby port of Apache::LogRegex Perl library.
A big thanks goes to Peter Hickman, the author of the original package. This Ruby GEM would probably not exists without your contribution!I also want to thank you Harry Fuecks and Hamish Morgan,
the authors of the Python[http://code.google.com/p/apachelog/] and PHP[http://kitty0.org/] ports.
First of all they gave me the inspiration to translate the original Perl code to Ruby,
as soon as I discovered nobody did it before me.
Last but not least, their library have been extremely useful to help me understand some obscure Perl statements
from the original package.== Author
* {Simone Carletti}[http://www.simonecarletti.com]
== Resources
* {Homepage}[http://code.simonecarletti.com/apachelogregex]
* {API}[http://apachelogregex.rubyforge.org]
* {Source}[http://github.com/weppos/apachelogregex]
* {Bugs & Features}[http://github.com/weppos/apachelogregex/issues]== Changelog
See the CHANGELOG.rdoc file for details.
== License
Copyright (c) 2008-2009 Simone Carletti, ApacheLogRegex is released under the MIT license.