317ca6da2209681119024c14d405601820b86b3e
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
Sebastian Hahn There is no wikileaks hidde...

Sebastian Hahn authored 14 years ago

22) example hidden service</a>.
Roger Dingledine whoops, i missed a whole do...

Roger Dingledine authored 18 years ago

23) </p>
24) 
25) <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

26) website. For the technical details of how the hidden service protocol
27) 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

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

Andrew Lewman authored 14 years ago

32) <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

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

Jens Kubieziel authored 16 years ago

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

Roger Dingledine authored 18 years ago

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

Roger Dingledine authored 16 years ago

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

Roger Dingledine authored 18 years ago

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

Andrew Lewman authored 14 years ago

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

Roger Dingledine authored 18 years ago

51) 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

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

Roger Dingledine authored 18 years ago

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

Roger Dingledine authored 16 years ago

58) "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

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

Roger Dingledine authored 16 years ago

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

Roger Dingledine authored 17 years ago

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

Roger Dingledine authored 18 years ago

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

Roger Dingledine authored 17 years ago

66) <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

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

Roger Dingledine authored 17 years ago

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

82) <kbd>./configure &amp;&amp; make</kbd>. Then <kbd>mkdir hidserv; cd
83) hidserv</kbd>, and run
84) <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

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

Roger Dingledine authored 18 years ago

116) </p>
117) 
118) <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

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

Roger Dingledine authored 17 years ago

120) 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

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

Roger Dingledine authored 18 years ago

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

Roger Dingledine authored 18 years ago

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

Jens Kubieziel authored 16 years ago

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

Roger Dingledine authored 18 years ago

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

Jens Kubieziel authored 16 years ago

134) <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

135) about that hidden service.  In particular, Tor will create a file here named
Sebastian Hahn Document that webroot and H...

Sebastian Hahn authored 14 years ago

136) <var>hostname</var> which will tell you the onion URL.  You don't need to
137) add any files to this directory. Make sure this is not the same directory
138) as the hidserv directory you created when setting up thttpd, as your
139) HiddenServiceDir contains secret information!</li>
Jens Kubieziel - HTML-ized the document a...

Jens Kubieziel authored 16 years ago

140) <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

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

Roger Dingledine authored 17 years ago

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

Roger Dingledine authored 18 years ago

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

Roger Dingledine authored 17 years ago

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

Roger Dingledine authored 18 years ago

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

Jens Kubieziel authored 16 years ago

153) <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

154) to an actual directory that is readable/writeable by the user that will
155) be running Tor. The above line should work if you're using the OS X Tor
Sebastian Hahn Make unix doc match windows...

Sebastian Hahn authored 14 years ago

156) package. On Unix, try "/home/username/hidden_service/" and fill in your own
Roger Dingledine whoops, i missed a whole do...

Roger Dingledine authored 18 years ago

157) username in place of "username". On Windows you might pick:</p>
158) <pre>
Roger Dingledine repair the tor hidden servi...

Roger Dingledine authored 18 years ago

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

Roger Dingledine authored 17 years ago

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

Roger Dingledine authored 18 years ago

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

Roger Dingledine authored 17 years ago

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

Roger Dingledine authored 18 years ago

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

Jens Kubieziel authored 16 years ago

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

Roger Dingledine authored 16 years ago

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

Roger Dingledine authored 17 years ago

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

Roger Dingledine authored 18 years ago

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

Jens Kubieziel authored 16 years ago

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

Bogdan Drozdowski authored 16 years ago

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

Jens Kubieziel authored 16 years ago

186) <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

187) 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

188) <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

189) 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

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

Roger Dingledine authored 16 years ago

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

Jens Kubieziel authored 16 years ago

192) 
193) <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

194) 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

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

Roger Dingledine authored 18 years ago

196) 
197) <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

198) in the Tor network, and generating a <em>hidden service
199) 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

200) the service's full public key. It anonymously publishes this descriptor
201) to the directory servers, and other people anonymously fetch it from the
202) directory servers when they're trying to access your service.
203) </p>
204) 
205) <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

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

Roger Dingledine authored 18 years ago

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

Roger Dingledine authored 17 years ago

213) <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

214) <br />
215) 
216) <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

217) 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

218) </p>
219) 
220) <p>We avoided recommending Apache above, a) because many people might
221) already be running it for a public web server on their computer, and b)
222) because it's big
223) and has lots of places where it might reveal your IP address or other
224) identifying information, for example in 404 pages. For people who need
225) more functionality, though, Apache may be the right answer. Can
226) 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

227) 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

228) </p>
229) 
230) <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

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

Roger Dingledine authored 18 years ago

232) 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

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

Roger Dingledine authored 18 years ago

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

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