40bb33d7d2b7c3bdce434c187e775e1704ac76d5
Roger Dingledine whoops, i missed a whole do...

Roger Dingledine authored 18 years ago

1) ## translation metadata
2) # Revision: $Revision$
Roger Dingledine add some more translation p...

Roger Dingledine authored 16 years ago

3) # Translation-Priority: 3-low
Roger Dingledine whoops, i missed a whole do...

Roger Dingledine authored 18 years ago

4) 
Runa A. Sandvik utf-8 ftw

Runa A. Sandvik authored 14 years ago

5) #include "head.wmi" TITLE="Tor: Hidden Service Configuration Instructions" CHARSET="UTF-8"
Roger Dingledine whoops, i missed a whole do...

Roger Dingledine authored 18 years ago

6) 
7) <div class="center">
8) 
9) <div class="main-column">
10) 
11) <h1>Configuring Hidden Services for <a href="<page index>">Tor</a></h1>
12) <hr />
13) 
Roger Dingledine continue the great relay te...

Roger Dingledine authored 16 years ago

14) <p>Tor allows clients and relays to offer hidden services. That is,
Roger Dingledine whoops, i missed a whole do...

Roger Dingledine authored 18 years ago

15) you can offer a web server, SSH server, etc., without revealing your
Roger Dingledine Get rid of the dangerous in...

Roger Dingledine authored 17 years ago

16) IP address to its users. In fact, because you don't use any public address,
Roger Dingledine whoops, i missed a whole do...

Roger Dingledine authored 18 years ago

17) you can run a hidden service from behind your firewall.
18) </p>
19) 
Andrew Lewman update to replace privoxy w...

Andrew Lewman authored 14 years ago

20) <p>If you have Tor installed, you can see hidden services
Roger Dingledine point to the wikileaks hidd...

Roger Dingledine authored 14 years ago

21) in action by visiting <a href="http://duskgytldkxiuqc6.onion/">our
22) example hidden service</a> or the <a
23) href="http://gaddbiwdftapglkq.onion/">Wikileaks hidden service</a>.
Roger Dingledine whoops, i missed a whole do...

Roger Dingledine authored 18 years ago

24) </p>
25) 
26) <p>This howto describes the steps for setting up your own hidden service
Jan Reister add cross reference to hidd...

Jan Reister authored 15 years ago

27) website. For the technical details of how the hidden service protocol
28) works, see our <a href="<page hidden-services>">hidden service protocol</a> page.
Roger Dingledine whoops, i missed a whole do...

Roger Dingledine authored 18 years ago

29) </p>
30) 
31) <hr />
32) <a id="zero"></a>
Andrew Lewman update to replace privoxy w...

Andrew Lewman authored 14 years ago

33) <h2><a class="anchor" href="#zero">Step Zero: Get Tor working</a></h2>
Roger Dingledine whoops, i missed a whole do...

Roger Dingledine authored 18 years ago

34) <br />
35) 
Jens Kubieziel - HTML-ized the document a...

Jens Kubieziel authored 16 years ago

36) <p>Before you start, you need to make sure:</p>
37) <ol>
38) <li>Tor is up and running,</li>
39) <li>You actually set it up correctly.</li>
40) </ol>
41) 
Roger Dingledine whoops, i missed a whole do...

Roger Dingledine authored 18 years ago

42) 
43) <p>Windows users should follow the <a
Roger Dingledine and change the links

Roger Dingledine authored 16 years ago

44) href="<page docs/tor-doc-windows>">Windows
Roger Dingledine whoops, i missed a whole do...

Roger Dingledine authored 18 years ago

45) howto</a>, OS X users should follow the <a
46) href="<page docs/tor-doc-osx>">OS
47) X howto</a>, and Linux/BSD/Unix users should follow the <a
48) href="<page docs/tor-doc-unix>">Unix howto</a>.
49) </p>
50) 
Andrew Lewman update to replace privoxy w...

Andrew Lewman authored 14 years ago

51) <p>Once you've got Tor installed and configured,
Roger Dingledine whoops, i missed a whole do...

Roger Dingledine authored 18 years ago

52) you can see hidden services in action by following this link to <a
Roger Dingledine point to the wikileaks hidd...

Roger Dingledine authored 14 years ago

53) href="http://duskgytldkxiuqc6.onion/">our example hidden service</a>
54) or the <a
55) href="http://gaddbiwdftapglkq.onion/">Wikileaks hidden service</a>.
Roger Dingledine whoops, i missed a whole do...

Roger Dingledine authored 18 years ago

56) It will typically take 10-60 seconds to load
57) (or to decide that it is currently unreachable). If it fails
58) immediately and your browser pops up an alert saying that
Roger Dingledine fix typo found by ruben

Roger Dingledine authored 16 years ago

59) "www.duskgytldkxiuqc6.onion could not be found, please check the name and
Andrew Lewman update to replace privoxy w...

Andrew Lewman authored 14 years ago

60) try again" then you haven't configured Tor correctly; see <a
Roger Dingledine patch from ararat to update...

Roger Dingledine authored 16 years ago

61) href="https://wiki.torproject.org/noreply/TheOnionRouter/TorFAQ#ItDoesntWork">the
Roger Dingledine Get rid of the dangerous in...

Roger Dingledine authored 17 years ago

62) it-doesn't-work FAQ entry</a> for some help.
Roger Dingledine whoops, i missed a whole do...

Roger Dingledine authored 18 years ago

63) </p>
64) 
65) <hr />
66) <a id="one"></a>
Roger Dingledine Get rid of the dangerous in...

Roger Dingledine authored 17 years ago

67) <h2><a class="anchor" href="#one">Step One: Install a web server locally</a></h2>
Roger Dingledine whoops, i missed a whole do...

Roger Dingledine authored 18 years ago

68) <br />
69) 
Roger Dingledine Get rid of the dangerous in...

Roger Dingledine authored 17 years ago

70) <p>First, you need to set up a web server locally. Setting up a web
71) server can be tricky,
72) so we're just going to go over a few basics here. If you get stuck
73) or want to do more, find a friend who can help you. We recommend you
74) install a new separate web server for your hidden service, since even
75) if you already have one installed, you may be using it (or want to use
76) it later) for an actual website.
77) </p>
78) 
79) <p>If you're on Unix or OS X and you're comfortable with
80) the command-line, by far the best way to go is to install <a
81) href="http://www.acme.com/software/thttpd/">thttpd</a>. Just grab the
82) latest tarball, untar it (it will create its own directory), and run
Jens Kubieziel - HTML-ized the document a...

Jens Kubieziel authored 16 years ago

83) <kbd>./configure &amp;&amp; make</kbd>. Then <kbd>mkdir hidserv; cd
84) hidserv</kbd>, and run
85) <kbd>../thttpd -p 5222 -h localhost</kbd>. It will give you back your prompt,
Roger Dingledine Get rid of the dangerous in...

Roger Dingledine authored 17 years ago

86) and now you're running a webserver on port 5222. You can put files to
87) serve in the hidserv directory.
88) </p>
89) 
90) <p>If you're on Windows, you might pick <a
91) href="http://savant.sourceforge.net/">Savant</a> or <a
92) href="http://httpd.apache.org/">Apache</a>, and be sure to configure it
93) to bind only to localhost. You should also figure out what port you're
94) listening on, because you'll use it below.
95) </p>
96) 
97) <p>(The reason we bind the web server only to localhost is to make
98) sure it isn't publically accessible. If people could get to it directly,
99) they could confirm that your computer is the one offering the hidden
100) service.)
101) </p>
102) 
103) <p>Once you've got your web server set up, make sure it works: open your
104) browser and go to <a
105) href="http://localhost:5222/">http://localhost:5222/</a>, where 5222 is
106) the port that you picked above. Then try putting a file in the main html
107) directory, and make sure it shows up when you access the site.
108) </p>
109) 
110) <hr />
111) <a id="two"></a>
112) <h2><a class="anchor" href="#two">Step Two: Configure your hidden service</a></h2>
113) <br />
114) 
115) <p>Next, you need to configure your hidden service to point to your
116) local web server.
Roger Dingledine whoops, i missed a whole do...

Roger Dingledine authored 18 years ago

117) </p>
118) 
119) <p>First, open your torrc file in your favorite text editor. (See <a
Roger Dingledine patch from ararat to update...

Roger Dingledine authored 16 years ago

120) href="https://wiki.torproject.org/noreply/TheOnionRouter/TorFAQ#torrc">the
Roger Dingledine Get rid of the dangerous in...

Roger Dingledine authored 17 years ago

121) torrc FAQ entry</a> to learn what this means.) Go to the middle section and
Roger Dingledine whoops, i missed a whole do...

Roger Dingledine authored 18 years ago

122) look for the line</p>
123) 
124) <pre>
Roger Dingledine and resolve the other use-o...

Roger Dingledine authored 18 years ago

125) \############### This section is just for location-hidden services ###
Roger Dingledine whoops, i missed a whole do...

Roger Dingledine authored 18 years ago

126) </pre>
127) 
128) <p>
129) This section of the file consists of groups of lines, each representing
130) one hidden service. Right now they are all commented out (the lines
131) start with #), so hidden services are disabled. Each group of lines
Jens Kubieziel - HTML-ized the document a...

Jens Kubieziel authored 16 years ago

132) consists of one <var>HiddenServiceDir</var> line, and one or more
133) <var>HiddenServicePort</var> lines:</p>
Roger Dingledine whoops, i missed a whole do...

Roger Dingledine authored 18 years ago

134) <ul>
Jens Kubieziel - HTML-ized the document a...

Jens Kubieziel authored 16 years ago

135) <li><var>HiddenServiceDir</var> is a directory where Tor will store information
Roger Dingledine whoops, i missed a whole do...

Roger Dingledine authored 18 years ago

136) about that hidden service.  In particular, Tor will create a file here named
Jens Kubieziel - HTML-ized the document a...

Jens Kubieziel authored 16 years ago

137) <var>hostname</var> which will tell you the onion URL.  You don't need to add any
Roger Dingledine whoops, i missed a whole do...

Roger Dingledine authored 18 years ago

138) files to this directory.</li>
Jens Kubieziel - HTML-ized the document a...

Jens Kubieziel authored 16 years ago

139) <li><var>HiddenServicePort</var> lets you specify a virtual port (that is, what
Roger Dingledine whoops, i missed a whole do...

Roger Dingledine authored 18 years ago

140) port people accessing the hidden service will think they're using) and an
141) IP address and port for redirecting connections to this virtual port.</li>
142) </ul>
143) 
Roger Dingledine Get rid of the dangerous in...

Roger Dingledine authored 17 years ago

144) <p>Add the following lines to your torrc:
Roger Dingledine whoops, i missed a whole do...

Roger Dingledine authored 18 years ago

145) </p>
146) 
147) <pre>
148) HiddenServiceDir /Library/Tor/var/lib/tor/hidden_service/
Roger Dingledine Get rid of the dangerous in...

Roger Dingledine authored 17 years ago

149) HiddenServicePort 80 127.0.0.1:5222
Roger Dingledine whoops, i missed a whole do...

Roger Dingledine authored 18 years ago

150) </pre>
151) 
Jens Kubieziel - HTML-ized the document a...

Jens Kubieziel authored 16 years ago

152) <p>You're going to want to change the <var>HiddenServiceDir</var> line, so it points
Roger Dingledine whoops, i missed a whole do...

Roger Dingledine authored 18 years ago

153) to an actual directory that is readable/writeable by the user that will
154) be running Tor. The above line should work if you're using the OS X Tor
155) package. On Unix, try "/home/username/hidserv/" and fill in your own
156) username in place of "username". On Windows you might pick:</p>
157) <pre>
Roger Dingledine repair the tor hidden servi...

Roger Dingledine authored 18 years ago

158) HiddenServiceDir C:\Documents and Settings\username\Application Data\hidden_service\\
Roger Dingledine Get rid of the dangerous in...

Roger Dingledine authored 17 years ago

159) HiddenServicePort 80 127.0.0.1:5222
Roger Dingledine whoops, i missed a whole do...

Roger Dingledine authored 18 years ago

160) </pre>
161) 
162) <p>Now save the torrc, shut down
Roger Dingledine Get rid of the dangerous in...

Roger Dingledine authored 17 years ago

163) your Tor, and then start it again.
Roger Dingledine whoops, i missed a whole do...

Roger Dingledine authored 18 years ago

164) </p>
165) 
Jens Kubieziel - HTML-ized the document a...

Jens Kubieziel authored 16 years ago

166) <p>If Tor starts up again, great. Otherwise, something is wrong. First look at
167) your logfiles for hints. It will print some warnings or error messages. That
168) should give you an idea what went wrong. Typically there are typos in the torrc
169) or wrong directory permissions (See <a
Roger Dingledine patch from ararat to update...

Roger Dingledine authored 16 years ago

170) href="https://wiki.torproject.org/noreply/TheOnionRouter/TorFAQ#Logs">the
Roger Dingledine Get rid of the dangerous in...

Roger Dingledine authored 17 years ago

171) logging FAQ entry</a> if you don't know how to enable or find your
172) log file.)
Roger Dingledine whoops, i missed a whole do...

Roger Dingledine authored 18 years ago

173) </p>
174) 
Jens Kubieziel - HTML-ized the document a...

Jens Kubieziel authored 16 years ago

175) <p>When Tor starts, it will automatically create the <var>HiddenServiceDir</var>
176) that you specified (if necessary), and it will create two files there.</p>
177) 
178) <dl>
179) <dt><var>private_key</var></dt>
180) <dd>First, Tor will generate a new public/private keypair for your hidden
181) service. It is written into a file called "private_key". Don't share this key
182) with others -- if you do they will be able to impersonate your hidden
183) service.</dd>
Bogdan Drozdowski Translation/mainetance upda...

Bogdan Drozdowski authored 16 years ago

184) <dt><var>hostname</var></dt>
Jens Kubieziel - HTML-ized the document a...

Jens Kubieziel authored 16 years ago

185) <dd>The other file Tor will create is called "hostname". This contains
Roger Dingledine whoops, i missed a whole do...

Roger Dingledine authored 18 years ago

186) a short summary of your public key -- it will look something like
Roger Dingledine an example hidden service t...

Roger Dingledine authored 16 years ago

187) <tt>duskgytldkxiuqc6.onion</tt>. This is the public name for your service,
Roger Dingledine whoops, i missed a whole do...

Roger Dingledine authored 18 years ago

188) and you can tell it to people, publish it on websites, put it on business
Jens Kubieziel - HTML-ized the document a...

Jens Kubieziel authored 16 years ago

189) cards, etc.</dd>
Roger Dingledine fix some broken html

Roger Dingledine authored 16 years ago

190) </dl>
Jens Kubieziel - HTML-ized the document a...

Jens Kubieziel authored 16 years ago

191) 
192) <p>If Tor runs as a different user than you, for example on
Roger Dingledine whoops, i missed a whole do...

Roger Dingledine authored 18 years ago

193) OS X, Debian, or Red Hat, then you may need to become root to be able
Jens Kubieziel - HTML-ized the document a...

Jens Kubieziel authored 16 years ago

194) to view these files.</p>
Roger Dingledine whoops, i missed a whole do...

Roger Dingledine authored 18 years ago

195) 
196) <p>Now that you've restarted Tor, it is busy picking introduction points
Jens Kubieziel - HTML-ized the document a...

Jens Kubieziel authored 16 years ago

197) in the Tor network, and generating a <em>hidden service
198) descriptor</em>. This is a signed list of introduction points along with
Roger Dingledine whoops, i missed a whole do...

Roger Dingledine authored 18 years ago

199) the service's full public key. It anonymously publishes this descriptor
200) to the directory servers, and other people anonymously fetch it from the
201) directory servers when they're trying to access your service.
202) </p>
203) 
204) <p>Try it now: paste the contents of the hostname file into your web
Roger Dingledine Get rid of the dangerous in...

Roger Dingledine authored 17 years ago

205) browser. If it works, you'll get the html page you set up in step one.
206) If it doesn't work, look in your logs for some hints, and keep playing
207) with it until it works.
Roger Dingledine whoops, i missed a whole do...

Roger Dingledine authored 18 years ago

208) </p>
209) 
210) <hr />
211) <a id="three"></a>
Roger Dingledine Get rid of the dangerous in...

Roger Dingledine authored 17 years ago

212) <h2><a class="anchor" href="#three">Step Three: More advanced tips</a></h2>
Roger Dingledine whoops, i missed a whole do...

Roger Dingledine authored 18 years ago

213) <br />
214) 
215) <p>If you plan to keep your service available for a long time, you might
Jens Kubieziel - HTML-ized the document a...

Jens Kubieziel authored 16 years ago

216) want to make a backup copy of the <var>private_key</var> file somewhere.
Roger Dingledine whoops, i missed a whole do...

Roger Dingledine authored 18 years ago

217) </p>
218) 
219) <p>We avoided recommending Apache above, a) because many people might
220) already be running it for a public web server on their computer, and b)
221) because it's big
222) and has lots of places where it might reveal your IP address or other
223) identifying information, for example in 404 pages. For people who need
224) more functionality, though, Apache may be the right answer. Can
225) somebody make us a checklist of ways to lock down your Apache when you're
Roger Dingledine recommend savant as a webse...

Roger Dingledine authored 17 years ago

226) using it as a hidden service? Savant probably has these problems too.
Roger Dingledine whoops, i missed a whole do...

Roger Dingledine authored 18 years ago

227) </p>
228) 
229) <p>If you want to forward multiple virtual ports for a single hidden
Jens Kubieziel - HTML-ized the document a...

Jens Kubieziel authored 16 years ago

230) service, just add more <var>HiddenServicePort</var> lines.
Roger Dingledine whoops, i missed a whole do...

Roger Dingledine authored 18 years ago

231) If you want to run multiple hidden services from the same Tor
Jens Kubieziel - HTML-ized the document a...

Jens Kubieziel authored 16 years ago

232) client, just add another <var>HiddenServiceDir</var> line. All the following
233) <var>HiddenServicePort</var> lines refer to this <var>HiddenServiceDir</var> line, until
234) you add another <var>HiddenServiceDir</var> line:
Roger Dingledine whoops, i missed a whole do...

Roger Dingledine authored 18 years ago

235) </p>
236) 
237) <pre>
238) HiddenServiceDir /usr/local/etc/tor/hidden_service/
239) HiddenServicePort 80 127.0.0.1:8080
240) 
241) HiddenServiceDir /usr/local/etc/tor/other_hidden_service/
242) HiddenServicePort 6667 127.0.0.1:6667
243) HiddenServicePort 22 127.0.0.1:22
244) </pre>
245) 
246) <p>There are some anonymity issues you should keep in mind too:
247) </p>
248) <ul>
249) <li>As mentioned above, be careful of letting your web server reveal
250) identifying information about you, your computer, or your location.
251) For example, readers can probably determine whether it's thttpd or
252) Apache, and learn something about your operating system.</li>
253) <li>If your computer isn't online all the time, your hidden service
254) won't be either. This leaks information to an observant adversary.</li>
255) <!-- increased risks over time -->
256) </ul>
257) 
258) <hr />
259) 
260) <p>If you have suggestions for improving this document, please <a
Roger Dingledine add a step to tor-doc-serve...

Roger Dingledine authored 18 years ago

261) href="<page contact>">send them to us</a>. Thanks!</p>