vizi_tracker 0.1.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (73) hide show
  1. data/README.rdoc +116 -0
  2. data/Rakefile +44 -0
  3. data/config/logger-backup.yml +49 -0
  4. data/config/logger.yml +69 -0
  5. data/config/logger_apache.yml +65 -0
  6. data/config/logger_sample.yml +69 -0
  7. data/data/exlog.log +5458 -0
  8. data/data/sample-alter.log +11870 -0
  9. data/data/sample-surf.log +47 -0
  10. data/data/sample-wle.log +30474 -0
  11. data/data/testlog.log +270 -0
  12. data/data/vizitrax.log +17951 -0
  13. data/doc/Object.html +200 -0
  14. data/doc/ParserTest.html +268 -0
  15. data/doc/README_rdoc.html +128 -0
  16. data/doc/Rakefile.html +148 -0
  17. data/doc/Visit.html +487 -0
  18. data/doc/VisitList.html +385 -0
  19. data/doc/Vizi/LogFormat.html +377 -0
  20. data/doc/Vizi/LogParser.html +551 -0
  21. data/doc/Vizi/Visit.html +487 -0
  22. data/doc/Vizi/VisitList.html +386 -0
  23. data/doc/Vizi.html +168 -0
  24. data/doc/ViziLogFormat.html +382 -0
  25. data/doc/ViziLogParser.html +551 -0
  26. data/doc/created.rid +8 -0
  27. data/doc/formats/apache-custom-log.pdf +0 -0
  28. data/doc/formats/apache.rtf +238 -0
  29. data/doc/formats/format-descriptions.xls +0 -0
  30. data/doc/formats/w3c-extended.pdf +0 -0
  31. data/doc/formats/w3c-extended.rtf +135 -0
  32. data/doc/images/brick.png +0 -0
  33. data/doc/images/brick_link.png +0 -0
  34. data/doc/images/bug.png +0 -0
  35. data/doc/images/bullet_black.png +0 -0
  36. data/doc/images/bullet_toggle_minus.png +0 -0
  37. data/doc/images/bullet_toggle_plus.png +0 -0
  38. data/doc/images/date.png +0 -0
  39. data/doc/images/find.png +0 -0
  40. data/doc/images/loadingAnimation.gif +0 -0
  41. data/doc/images/macFFBgHack.png +0 -0
  42. data/doc/images/package.png +0 -0
  43. data/doc/images/page_green.png +0 -0
  44. data/doc/images/page_white_text.png +0 -0
  45. data/doc/images/page_white_width.png +0 -0
  46. data/doc/images/plugin.png +0 -0
  47. data/doc/images/ruby.png +0 -0
  48. data/doc/images/tag_green.png +0 -0
  49. data/doc/images/wrench.png +0 -0
  50. data/doc/images/wrench_orange.png +0 -0
  51. data/doc/images/zoom.png +0 -0
  52. data/doc/index.html +112 -0
  53. data/doc/js/darkfish.js +116 -0
  54. data/doc/js/jquery.js +32 -0
  55. data/doc/js/quicksearch.js +114 -0
  56. data/doc/js/thickbox-compressed.js +10 -0
  57. data/doc/lib/vizi/parser_rb.html +63 -0
  58. data/doc/lib/vizi/vizi_tracker_rb.html +63 -0
  59. data/doc/lib/vizi_log_parser_rb.html +56 -0
  60. data/doc/lib/vizi_tracker_rb.html +56 -0
  61. data/doc/rdoc.css +759 -0
  62. data/doc/test/parser_test_rb.html +54 -0
  63. data/doc/test/test_helper_rb.html +56 -0
  64. data/doc/testit_rb.html +63 -0
  65. data/lib/vizi/vizi_tracker.rb +406 -0
  66. data/lib/vizi_tracker.rb +5 -0
  67. data/log/parse.log +79 -0
  68. data/log/system.log +66 -0
  69. data/test/parser_test.rb +48 -0
  70. data/test/test_helper.rb +3 -0
  71. data/testit.rb +105 -0
  72. data/vizi_tracker.gemspec +21 -0
  73. metadata +146 -0
@@ -0,0 +1,382 @@
1
+ <?xml version="1.0" encoding="IBM437"?>
2
+ <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
3
+ "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
4
+ <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
5
+ <head>
6
+ <meta content="text/html; charset=IBM437" http-equiv="Content-Type" />
7
+
8
+ <title>Class: ViziLogFormat</title>
9
+
10
+ <link rel="stylesheet" href="./rdoc.css" type="text/css" media="screen" />
11
+
12
+ <script src="./js/jquery.js" type="text/javascript" charset="utf-8"></script>
13
+ <script src="./js/thickbox-compressed.js" type="text/javascript" charset="utf-8"></script>
14
+ <script src="./js/quicksearch.js" type="text/javascript" charset="utf-8"></script>
15
+ <script src="./js/darkfish.js" type="text/javascript" charset="utf-8"></script>
16
+
17
+ </head>
18
+ <body id="top" class="class">
19
+
20
+ <div id="metadata">
21
+ <div id="home-metadata">
22
+ <div id="home-section" class="section">
23
+ <h3 class="section-header">
24
+ <a href="./index.html">Home</a>
25
+ <a href="./index.html#classes">Classes</a>
26
+ <a href="./index.html#methods">Methods</a>
27
+ </h3>
28
+ </div>
29
+ </div>
30
+
31
+ <div id="file-metadata">
32
+ <div id="file-list-section" class="section">
33
+ <h3 class="section-header">In Files</h3>
34
+ <div class="section-body">
35
+ <ul>
36
+
37
+ <li><a href="./lib/vizi/parser_rb.html?TB_iframe=true&amp;height=550&amp;width=785"
38
+ class="thickbox" title="lib/vizi/parser.rb">lib/vizi/parser.rb</a></li>
39
+
40
+ </ul>
41
+ </div>
42
+ </div>
43
+
44
+
45
+ </div>
46
+
47
+ <div id="class-metadata">
48
+
49
+ <!-- Parent Class -->
50
+ <div id="parent-class-section" class="section">
51
+ <h3 class="section-header">Parent</h3>
52
+
53
+ <p class="link"><a href="Object.html">Object</a></p>
54
+
55
+ </div>
56
+
57
+
58
+
59
+
60
+
61
+
62
+
63
+ <!-- Method Quickref -->
64
+ <div id="method-list-section" class="section">
65
+ <h3 class="section-header">Methods</h3>
66
+ <ul class="link-list">
67
+
68
+ <li><a href="#method-c-new">::new</a></li>
69
+
70
+ <li><a href="#method-i-parse_format">#parse_format</a></li>
71
+
72
+ <li><a href="#method-i-process_directive">#process_directive</a></li>
73
+
74
+ </ul>
75
+ </div>
76
+
77
+
78
+
79
+ </div>
80
+
81
+ <div id="project-metadata">
82
+
83
+
84
+ <div id="fileindex-section" class="section project-section">
85
+ <h3 class="section-header">Files</h3>
86
+ <ul>
87
+
88
+ <li class="file"><a href="./README_rdoc.html">README.rdoc</a></li>
89
+
90
+ <li class="file"><a href="./Rakefile.html">Rakefile</a></li>
91
+
92
+ </ul>
93
+ </div>
94
+
95
+
96
+ <div id="classindex-section" class="section project-section">
97
+ <h3 class="section-header">Class/Module Index
98
+ <span class="search-toggle"><img src="./images/find.png"
99
+ height="16" width="16" alt="[+]"
100
+ title="show/hide quicksearch" /></span></h3>
101
+ <form action="#" method="get" accept-charset="utf-8" class="initially-hidden">
102
+ <fieldset>
103
+ <legend>Quicksearch</legend>
104
+ <input type="text" name="quicksearch" value=""
105
+ class="quicksearch-field" />
106
+ </fieldset>
107
+ </form>
108
+
109
+ <ul class="link-list">
110
+
111
+ <li><a href="./Object.html">Object</a></li>
112
+
113
+ <li><a href="./ParserTest.html">ParserTest</a></li>
114
+
115
+ <li><a href="./Visit.html">Visit</a></li>
116
+
117
+ <li><a href="./VisitList.html">VisitList</a></li>
118
+
119
+ <li><a href="./ViziLogFormat.html">ViziLogFormat</a></li>
120
+
121
+ <li><a href="./ViziLogParser.html">ViziLogParser</a></li>
122
+
123
+ </ul>
124
+ <div id="no-class-search-results" style="display: none;">No matching classes.</div>
125
+ </div>
126
+
127
+
128
+ </div>
129
+ </div>
130
+
131
+ <div id="documentation">
132
+ <h1 class="class">ViziLogFormat</h1>
133
+
134
+ <div id="description" class="description">
135
+
136
+ <h1><a href="ViziLogFormat.html">ViziLogFormat</a></h1>
137
+ <table class="rdoc-list"><tr><td class="rdoc-term"><p>Author</p></td>
138
+ <td>
139
+ <p>Al Kivi &lt;admin@viztrax.com&gt;</p>
140
+ </td></tr><tr><td class="rdoc-term"><p>License</p></td>
141
+ <td>
142
+ <p>MIT</p>
143
+ </td></tr></table>
144
+
145
+ </div><!-- description -->
146
+
147
+
148
+ <div id="5Buntitled-5D" class="documentation-section">
149
+
150
+
151
+
152
+
153
+
154
+ <!-- Constants -->
155
+ <div id="constants-list" class="section">
156
+ <h3 class="section-header">Constants</h3>
157
+ <dl>
158
+
159
+ <dt><a name="DIRECTIVES">DIRECTIVES</a></dt>
160
+
161
+ <dd class="description"><p>add more format directives here..</p></dd>
162
+
163
+
164
+ </dl>
165
+ </div>
166
+
167
+
168
+
169
+ <!-- Attributes -->
170
+ <div id="attribute-method-details" class="method-section section">
171
+ <h3 class="section-header">Attributes</h3>
172
+
173
+
174
+ <div id="format-attribute-method" class="method-detail">
175
+ <a name="format"></a>
176
+
177
+ <div class="method-heading attribute-method-heading">
178
+ <span class="method-name">format</span><span
179
+ class="attribute-access-type">[R]</span>
180
+ </div>
181
+
182
+ <div class="method-description">
183
+
184
+
185
+
186
+ </div>
187
+ </div>
188
+
189
+ <div id="format_regex-attribute-method" class="method-detail">
190
+ <a name="format_regex"></a>
191
+
192
+ <div class="method-heading attribute-method-heading">
193
+ <span class="method-name">format_regex</span><span
194
+ class="attribute-access-type">[R]</span>
195
+ </div>
196
+
197
+ <div class="method-description">
198
+
199
+
200
+
201
+ </div>
202
+ </div>
203
+
204
+ <div id="format_symbols-attribute-method" class="method-detail">
205
+ <a name="format_symbols"></a>
206
+
207
+ <div class="method-heading attribute-method-heading">
208
+ <span class="method-name">format_symbols</span><span
209
+ class="attribute-access-type">[R]</span>
210
+ </div>
211
+
212
+ <div class="method-description">
213
+
214
+
215
+
216
+ </div>
217
+ </div>
218
+
219
+ <div id="name-attribute-method" class="method-detail">
220
+ <a name="name"></a>
221
+
222
+ <div class="method-heading attribute-method-heading">
223
+ <span class="method-name">name</span><span
224
+ class="attribute-access-type">[R]</span>
225
+ </div>
226
+
227
+ <div class="method-description">
228
+
229
+
230
+
231
+ </div>
232
+ </div>
233
+
234
+ </div><!-- attribute-method-details -->
235
+
236
+
237
+ <!-- Methods -->
238
+
239
+ <div id="public-class-method-details" class="method-section section">
240
+ <h3 class="section-header">Public Class Methods</h3>
241
+
242
+
243
+ <div id="new-method" class="method-detail ">
244
+ <a name="method-c-new"></a>
245
+
246
+
247
+ <div class="method-heading">
248
+ <span class="method-name">new</span><span
249
+ class="method-args">(name, format)</span>
250
+ <span class="method-click-advice">click to toggle source</span>
251
+ </div>
252
+
253
+
254
+ <div class="method-description">
255
+
256
+
257
+
258
+
259
+
260
+ <div class="method-source-code" id="new-source">
261
+ <pre>
262
+ <span class="ruby-comment"># File lib/vizi/parser.rb, line 39</span>
263
+ <span class="ruby-keyword">def</span> <span class="ruby-identifier">initialize</span>(<span class="ruby-identifier">name</span>, <span class="ruby-identifier">format</span>)
264
+ <span class="ruby-ivar">@name</span>, <span class="ruby-ivar">@format</span> = <span class="ruby-identifier">name</span>, <span class="ruby-identifier">format</span>
265
+ <span class="ruby-identifier">parse_format</span>(<span class="ruby-identifier">format</span>)
266
+ <span class="ruby-keyword">end</span></pre>
267
+ </div><!-- new-source -->
268
+
269
+ </div>
270
+
271
+
272
+
273
+
274
+ </div><!-- new-method -->
275
+
276
+
277
+ </div><!-- public-class-method-details -->
278
+
279
+ <div id="public-instance-method-details" class="method-section section">
280
+ <h3 class="section-header">Public Instance Methods</h3>
281
+
282
+
283
+ <div id="parse_format-method" class="method-detail ">
284
+ <a name="method-i-parse_format"></a>
285
+
286
+
287
+ <div class="method-heading">
288
+ <span class="method-name">parse_format</span><span
289
+ class="method-args">(format)</span>
290
+ <span class="method-click-advice">click to toggle source</span>
291
+ </div>
292
+
293
+
294
+ <div class="method-description">
295
+
296
+ <p>The symbols are used to map the log to the env variables The regex is used
297
+ when checking what format the log is and to extract data</p>
298
+
299
+
300
+
301
+ <div class="method-source-code" id="parse_format-source">
302
+ <pre>
303
+ <span class="ruby-comment"># File lib/vizi/parser.rb, line 46</span>
304
+ <span class="ruby-keyword">def</span> <span class="ruby-identifier">parse_format</span>(<span class="ruby-identifier">format</span>)
305
+ <span class="ruby-identifier">format_directive</span> = <span class="ruby-node">/%(.*?)(\{.*?\})?([#{[DIRECTIVES.keys.join('|')]}])([\s\\&quot;]*)/</span>
306
+ <span class="ruby-identifier">log_format_symbols</span> = []
307
+ <span class="ruby-identifier">format_regex</span> = <span class="ruby-string">&quot;&quot;</span>
308
+ <span class="ruby-identifier">format</span>.<span class="ruby-identifier">scan</span>(<span class="ruby-identifier">format_directive</span>) <span class="ruby-keyword">do</span> <span class="ruby-operator">|</span><span class="ruby-identifier">condition</span>, <span class="ruby-identifier">subdirective</span>, <span class="ruby-identifier">directive_char</span>, <span class="ruby-identifier">ignored</span><span class="ruby-operator">|</span>
309
+ <span class="ruby-identifier">log_format</span>, <span class="ruby-identifier">match_regex</span> = <span class="ruby-identifier">process_directive</span>(<span class="ruby-identifier">directive_char</span>, <span class="ruby-identifier">subdirective</span>, <span class="ruby-identifier">condition</span>)
310
+ <span class="ruby-identifier">ignored</span>.<span class="ruby-identifier">gsub!</span>(<span class="ruby-regexp">/\s/</span>, <span class="ruby-string">'\s'</span>) <span class="ruby-keyword">unless</span> <span class="ruby-identifier">ignored</span>.<span class="ruby-identifier">nil?</span>
311
+ <span class="ruby-identifier">log_format_symbols</span> <span class="ruby-operator">&lt;&lt;</span> <span class="ruby-identifier">log_format</span>
312
+ <span class="ruby-identifier">format_regex</span> <span class="ruby-operator">&lt;&lt;</span> <span class="ruby-node">&quot;(#{match_regex})#{ignored}&quot;</span>
313
+ <span class="ruby-keyword">end</span>
314
+ <span class="ruby-ivar">@format_symbols</span> = <span class="ruby-identifier">log_format_symbols</span>
315
+ <span class="ruby-ivar">@format_regex</span> = <span class="ruby-node">/^#{format_regex}/</span>
316
+ <span class="ruby-keyword">end</span></pre>
317
+ </div><!-- parse_format-source -->
318
+
319
+ </div>
320
+
321
+
322
+
323
+
324
+ </div><!-- parse_format-method -->
325
+
326
+
327
+ <div id="process_directive-method" class="method-detail ">
328
+ <a name="method-i-process_directive"></a>
329
+
330
+
331
+ <div class="method-heading">
332
+ <span class="method-name">process_directive</span><span
333
+ class="method-args">(directive_char, subdirective, condition)</span>
334
+ <span class="method-click-advice">click to toggle source</span>
335
+ </div>
336
+
337
+
338
+ <div class="method-description">
339
+
340
+
341
+
342
+
343
+
344
+ <div class="method-source-code" id="process_directive-source">
345
+ <pre>
346
+ <span class="ruby-comment"># File lib/vizi/parser.rb, line 60</span>
347
+ <span class="ruby-keyword">def</span> <span class="ruby-identifier">process_directive</span>(<span class="ruby-identifier">directive_char</span>, <span class="ruby-identifier">subdirective</span>, <span class="ruby-identifier">condition</span>)
348
+ <span class="ruby-identifier">directive</span> = <span class="ruby-constant">DIRECTIVES</span>[<span class="ruby-identifier">directive_char</span>]
349
+ <span class="ruby-keyword">case</span> <span class="ruby-identifier">directive_char</span>
350
+ <span class="ruby-keyword">when</span> <span class="ruby-string">'i'</span>
351
+ <span class="ruby-identifier">log_format</span> = <span class="ruby-identifier">subdirective</span>[<span class="ruby-value">1</span><span class="ruby-operator">...</span><span class="ruby-value">-1</span>].<span class="ruby-identifier">downcase</span>.<span class="ruby-identifier">tr</span>(<span class="ruby-string">'-'</span>, <span class="ruby-string">'_'</span>).<span class="ruby-identifier">to_sym</span>
352
+ [<span class="ruby-identifier">log_format</span>, <span class="ruby-identifier">directive</span>[<span class="ruby-value">1</span>].<span class="ruby-identifier">source</span>]
353
+ <span class="ruby-keyword">else</span>
354
+ [<span class="ruby-identifier">directive</span>[<span class="ruby-value">0</span>], <span class="ruby-identifier">directive</span>[<span class="ruby-value">1</span>].<span class="ruby-identifier">source</span>]
355
+ <span class="ruby-keyword">end</span>
356
+ <span class="ruby-keyword">end</span></pre>
357
+ </div><!-- process_directive-source -->
358
+
359
+ </div>
360
+
361
+
362
+
363
+
364
+ </div><!-- process_directive-method -->
365
+
366
+
367
+ </div><!-- public-instance-method-details -->
368
+
369
+ </div><!-- 5Buntitled-5D -->
370
+
371
+
372
+ </div><!-- documentation -->
373
+
374
+ <div id="validator-badges">
375
+ <p><small><a href="http://validator.w3.org/check/referer">[Validate]</a></small></p>
376
+ <p><small>Generated with the <a href="http://deveiate.org/projects/Darkfish-Rdoc/">Darkfish
377
+ Rdoc Generator</a> 2</small>.</p>
378
+ </div>
379
+
380
+ </body>
381
+ </html>
382
+