]> git.cworth.org Git - sup/blob - bin/sup-add
explicitly require a uri paths in bin/sup-add
[sup] / bin / sup-add
1 #!/usr/bin/env ruby
2
3 require 'uri'
4 require 'rubygems'
5 require 'highline/import'
6 require 'trollop'
7 require "sup"
8
9 $opts = Trollop::options do
10   version "sup-add (sup #{Redwood::VERSION})"
11   banner <<EOS
12 Adds a source to the Sup source list.
13
14 Usage:
15   sup-add [options] <source uri>+
16
17 where <source uri>+ is one or more source URIs.
18
19 For mbox files on local disk, use the form:
20     mbox:<path to mbox file>, or
21     mbox://<path to mbox file>
22
23 For mbox files on remote machines, use the form:
24     mbox+ssh://<machine name>/<path to mbox file>
25
26 For IMAP folders, use the form (note no username or password!):
27     imap://<machine name>/          # unsecure, "INBOX" folder  
28     imap://<machine name>/<folder>  # unsecure, arbitrary
29     imaps://<machine name>/         # secure, "INBOX" folder
30     imaps://<machine name>/<folder> # secure, arbitrary folder 
31
32 For Maildir folders, use the form:
33     maildir:<path to Maildir directory>; or
34     maildir://<path to Maildir directory>
35
36 Options are:
37 EOS
38   opt :archive, "Automatically archive all new messages from these sources."
39   opt :unusual, "Do not automatically poll these sources for new messages."
40   opt :force_new, "Create a new account for this source, even if one already exists."
41 end
42
43 Trollop::die "require one or more sources" if ARGV.empty?
44
45 ## for sources that require login information, prompt the user for
46 ## that. also provide a list of previously-defined login info to
47 ## choose from, if any.
48 def get_login_info uri, sources
49   uri = URI(uri)
50   accounts = sources.map do |s|
51     next unless s.respond_to?(:username)
52     suri = URI(s.uri)
53     [suri.host, s.username, s.password]
54   end.compact.uniq.sort_by { |h, u, p| h == uri.host ? 0 : 1 }
55
56   username, password = nil, nil
57   unless accounts.empty? || $opts[:force_new]
58     say "Would you like to use the same account as for a previous source for #{uri}?"
59     choose do |menu|
60       accounts.each do |host, olduser, oldpw|
61         menu.choice("Use the account info for #{olduser}@#{host}") { username, password = olduser, oldpw }
62       end
63       menu.choice("Use a new account") { }
64       menu.prompt = "Account selection? "
65     end
66   end
67
68   unless username && password
69     username = ask("Username for #{uri.host}: ");
70     password = ask("Password for #{uri.host}: ") { |q| q.echo = false }
71     puts # why?
72   end
73
74   [username, password]
75 end
76
77 $terminal.wrap_at = :auto
78 Redwood::start
79 index = Redwood::Index.new
80 index.load
81
82 ARGV.each do |uri|
83   if !$opts[:force_new] && index.source_for(uri) 
84     say "Already know about #{uri}; skipping."
85     next
86   end
87
88   parsed_uri = URI(uri)
89   Trollop::die "no path component to uri: #{parsed_uri}" unless parsed_uri.path
90
91   source = 
92     case parsed_uri.scheme
93     when "mbox+ssh"
94       say "For SSH connections, if you will use public key authentication, you may leave the username and password blank."
95       say ""
96       username, password = get_login_info uri, index.sources
97       Redwood::MBox::SSHLoader.new uri, username, password, nil, !$opts[:unusual], $opts[:archive]
98     when "imap", "imaps"
99       username, password = get_login_info uri, index.sources
100       Redwood::IMAP.new uri, username, password, nil, !$opts[:unusual], $opts[:archive]
101     when "maildir"
102       Redwood::Maildir.new uri, nil, !$opts[:unusual], $opts[:archive]
103     when "mbox"
104       Redwood::MBox::Loader.new uri, nil, !$opts[:unusual], $opts[:archive]
105     else
106       Trollop::die "Unknown source type #{parsed_uri.scheme.inspect}"      
107     end
108   say "Adding #{source}..."
109   index.add_source source
110 end
111
112 index.save
113 Redwood::finish