8ad09bf87907ace20d0ae691ae43481c4d01cc6a
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) 
Roger Dingledine similar patch on the docs/e...

Roger Dingledine authored 18 years ago

5) #include "head.wmi" TITLE="Hidden Service Configuration Instructions"
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) 
20) <p>If you have Tor and Privoxy installed, you can see hidden services
Roger Dingledine an example hidden service t...

Roger Dingledine authored 16 years ago

21) in action by visiting <a href="http://duskgytldkxiuqc6.onion/">an
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
26) website.
27) </p>
28) 
29) <hr />
30) <a id="zero"></a>
31) <h2><a class="anchor" href="#zero">Step Zero: Get Tor and Privoxy working</a></h2>
32) <br />
33) 
Jens Kubieziel - HTML-ized the document a...

Jens Kubieziel authored 16 years ago

34) <p>Before you start, you need to make sure:</p>
35) <ol>
36) <li>Tor is up and running,</li>
37) <li>Privoxy is up and running,</li>
38) <li>Privoxy is configured to point to Tor and</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) 
51) <p>Once you've got Tor and Privoxy installed and configured,
52) you can see hidden services in action by following this link to <a
yGREK Heretix minor fix : duskgytldkxiuqc...

yGREK Heretix authored 16 years ago

53) href="http://duskgytldkxiuqc6.onion/">an example hidden service</a>.
Roger Dingledine whoops, i missed a whole do...

Roger Dingledine authored 18 years ago

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

Roger Dingledine authored 16 years ago

57) "www.duskgytldkxiuqc6.onion could not be found, please check the name and
Roger Dingledine whoops, i missed a whole do...

Roger Dingledine authored 18 years ago

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

Roger Dingledine authored 16 years ago

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

Roger Dingledine authored 17 years ago

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

Roger Dingledine authored 18 years ago

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

Roger Dingledine authored 17 years ago

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

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

Roger Dingledine authored 17 years ago

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

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

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

Roger Dingledine authored 18 years ago

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

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

Roger Dingledine authored 17 years ago

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

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

Roger Dingledine authored 18 years ago

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

Roger Dingledine authored 18 years ago

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

Jens Kubieziel authored 16 years ago

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

Roger Dingledine authored 18 years ago

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

Jens Kubieziel authored 16 years ago

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

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

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

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

Jens Kubieziel authored 16 years ago

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

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

Roger Dingledine authored 17 years ago

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

Roger Dingledine authored 18 years ago

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

Roger Dingledine authored 17 years ago

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

Roger Dingledine authored 18 years ago

148) </pre>
149) 
Jens Kubieziel - HTML-ized the document a...

Jens Kubieziel authored 16 years ago

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

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

Roger Dingledine authored 18 years ago

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

Roger Dingledine authored 17 years ago

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

Roger Dingledine authored 18 years ago

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

Roger Dingledine authored 17 years ago

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

Roger Dingledine authored 18 years ago

162) </p>
163) 
Jens Kubieziel - HTML-ized the document a...

Jens Kubieziel authored 16 years ago

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

Roger Dingledine authored 16 years ago

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

Roger Dingledine authored 17 years ago

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

Roger Dingledine authored 18 years ago

171) </p>
172) 
Jens Kubieziel - HTML-ized the document a...

Jens Kubieziel authored 16 years ago

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

Bogdan Drozdowski authored 16 years ago

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

Jens Kubieziel authored 16 years ago

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

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

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

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

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

Roger Dingledine authored 16 years ago

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

Jens Kubieziel authored 16 years ago

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

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

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

Roger Dingledine authored 18 years ago

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

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

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

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

Roger Dingledine authored 18 years ago

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

Roger Dingledine authored 17 years ago

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

211) <br />
212) 
213) <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

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

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

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

225) </p>
226) 
227) <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

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

Roger Dingledine authored 18 years ago

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

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

Roger Dingledine authored 18 years ago

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

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