Add some code for Firefox cookie extraction. Change file naming scheme for consistency.

This commit is contained in:
Jeff Dallien 2012-02-20 18:32:39 -05:00 committed by Jeff Dallien
parent 2136ec8042
commit 6bc06df239
12 changed files with 216 additions and 11 deletions

View file

@ -1,4 +1,4 @@
source "http://rubygems.org" source "http://rubygems.org"
# Specify your gem's dependencies in cookie-extractor.gemspec # Specify your gem's dependencies in cookie_extractor.gemspec
gemspec gemspec

28
Gemfile.lock Normal file
View file

@ -0,0 +1,28 @@
PATH
remote: .
specs:
cookie_extractor (0.0.1)
sqlite3-ruby
GEM
remote: http://rubygems.org/
specs:
diff-lcs (1.1.3)
rspec (2.8.0)
rspec-core (~> 2.8.0)
rspec-expectations (~> 2.8.0)
rspec-mocks (~> 2.8.0)
rspec-core (2.8.0)
rspec-expectations (2.8.0)
diff-lcs (~> 1.1.2)
rspec-mocks (2.8.0)
sqlite3 (1.3.5)
sqlite3-ruby (1.3.3)
sqlite3 (>= 1.3.3)
PLATFORMS
ruby
DEPENDENCIES
cookie_extractor!
rspec

13
bin/cookie-extractor Executable file
View file

@ -0,0 +1,13 @@
#!/usr/bin/env ruby
require File.expand_path(File.join(File.dirname(__FILE__), "..", "lib", "cookie_extractor"))
Main do
# TODO: detect firefox or chrome input file and/or locate it automatically
filename = ARGV.first
if filename
puts CookieExtractor::FirefoxCookieExtractor.new(filename).extract.join("\n")
else
puts "Usage: cookie-extractor /path/to/cookies.sqlite"
end
end

View file

@ -1,9 +1,9 @@
# -*- encoding: utf-8 -*- # -*- encoding: utf-8 -*-
$:.push File.expand_path("../lib", __FILE__) $:.push File.expand_path("../lib", __FILE__)
require "cookie-extractor/version" require "cookie_extractor/version"
Gem::Specification.new do |s| Gem::Specification.new do |s|
s.name = "cookie-extractor" s.name = "cookie_extractor"
s.version = CookieExtractor::VERSION s.version = CookieExtractor::VERSION
s.authors = ["Jeff Dallien"] s.authors = ["Jeff Dallien"]
s.email = ["jeff@dallien.net"] s.email = ["jeff@dallien.net"]
@ -11,7 +11,7 @@ Gem::Specification.new do |s|
s.summary = %q{Create cookies.txt from Firefox or Chrome cookies} s.summary = %q{Create cookies.txt from Firefox or Chrome cookies}
s.description = %q{Extract cookies from Firefox or Chrome sqlite databases into a wget-compatible cookies.txt file.} s.description = %q{Extract cookies from Firefox or Chrome sqlite databases into a wget-compatible cookies.txt file.}
s.rubyforge_project = "cookie-extractor" s.rubyforge_project = "cookie_extractor"
s.files = `git ls-files`.split("\n") s.files = `git ls-files`.split("\n")
s.test_files = `git ls-files -- {test,spec,features}/*`.split("\n") s.test_files = `git ls-files -- {test,spec,features}/*`.split("\n")

View file

@ -1,7 +0,0 @@
require "cookie-extractor/version"
module Cookie
module Extractor
# Your code goes here...
end
end

5
lib/cookie_extractor.rb Normal file
View file

@ -0,0 +1,5 @@
require "cookie_extractor/version"
require "cookie_extractor/firefox_cookie_extractor"
module CookieExtractor
end

View file

@ -0,0 +1,42 @@
require 'sqlite3'
module CookieExtractor
class FirefoxCookieExtractor
def initialize(cookie_file)
@cookie_file = cookie_file
end
def extract
db = SQLite3::Database.new @cookie_file
db.results_as_hash = true
@result = []
db.execute("SELECT * FROM moz_cookies") do |row|
@result << [ row['host'],
true_false_word(is_domain_wide(row['host'])),
row['path'],
true_false_word(row['isSecure']),
row['expiry'],
row['name'],
row['value']
].join("\t")
end
end
private
def is_domain_wide(hostname)
hostname[0..0] == "."
end
def true_false_word(value)
if value == "1" || value == 1 || value == true
"TRUE"
elsif value == "0" || value == 0 || value == false
"FALSE"
else
raise "Invalid value passed to true_false_word: #{value.inspect}"
end
end
end
end

Binary file not shown.

View file

@ -0,0 +1,6 @@
require File.join(File.dirname(__FILE__), "spec_helper")
describe CookieExtractor do
end

View file

@ -0,0 +1,116 @@
require File.join(File.dirname(__FILE__), "spec_helper")
describe CookieExtractor::FirefoxCookieExtractor do
before :each do
@fake_cookie_db = double("cookie database", :results_as_hash= => true)
SQLite3::Database.should_receive(:new).
with('filename').
and_return(@fake_cookie_db)
end
describe "with a cookie that has a host starting with a dot" do
before :each do
@fake_cookie_db.should_receive(:execute).and_yield(
{'host' => '.dallien.net',
'path' => '/',
'isSecure' => '0',
'expiry' => '1234567890',
'name' => 'NAME',
'value' => 'VALUE'})
@extractor = CookieExtractor::FirefoxCookieExtractor.new('filename')
@result = @extractor.extract
end
it "should return one cookie string" do
@result.size.should == 1
end
it "should put TRUE in the domain wide field" do
cookie_string = @result.first
cookie_string.split("\t")[1].should == "TRUE"
end
it "should put FALSE in the secure field" do
cookie_string = @result.first
cookie_string.split("\t")[3].should == "FALSE"
end
it "should build the correct cookie string" do
cookie_string = @result.first
cookie_string.should ==
".dallien.net\tTRUE\t/\tFALSE\t1234567890\tNAME\tVALUE"
end
end
describe "with a cookie that has a host not starting with a dot" do
before :each do
@fake_cookie_db.should_receive(:execute).and_yield(
{ 'host' => 'jeff.dallien.net',
'path' => '/path',
'isSecure' => '1',
'expiry' => '1234567890',
'name' => 'NAME',
'value' => 'VALUE'})
@extractor = CookieExtractor::FirefoxCookieExtractor.new('filename')
@result = @extractor.extract
end
it "should return one cookie string" do
@result.size.should == 1
end
it "should put FALSE in the domain wide field" do
cookie_string = @result.first
cookie_string.split("\t")[1].should == "FALSE"
end
it "should put TRUE in the secure field" do
cookie_string = @result.first
cookie_string.split("\t")[3].should == "TRUE"
end
it "should build the correct cookie string" do
cookie_string = @result.first
cookie_string.should ==
"jeff.dallien.net\tFALSE\t/path\tTRUE\t1234567890\tNAME\tVALUE"
end
end
describe "with a cookie that is not marked as secure" do
before :each do
@fake_cookie_db.should_receive(:execute).and_yield(
{'host' => '.dallien.net',
'path' => '/',
'isSecure' => '0',
'expiry' => '1234567890',
'name' => 'NAME',
'value' => 'VALUE'})
@extractor = CookieExtractor::FirefoxCookieExtractor.new('filename')
@result = @extractor.extract
end
it "should put FALSE in the secure field" do
cookie_string = @result.first
cookie_string.split("\t")[3].should == "FALSE"
end
end
describe "with a cookie that is marked as secure" do
before :each do
@fake_cookie_db.should_receive(:execute).and_yield(
{'host' => '.dallien.net',
'path' => '/',
'isSecure' => '1',
'expiry' => '1234567890',
'name' => 'NAME',
'value' => 'VALUE'})
@extractor = CookieExtractor::FirefoxCookieExtractor.new('filename')
@result = @extractor.extract
end
it "should put TRUE in the secure field" do
cookie_string = @result.first
cookie_string.split("\t")[3].should == "TRUE"
end
end
end

2
spec/spec_helper.rb Normal file
View file

@ -0,0 +1,2 @@
require File.expand_path(File.join(File.dirname(__FILE__), "..", "lib", "cookie_extractor"))