<?xml version="1.0" encoding="UTF-8"?><rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	>
<channel>
	<title>Comments on: Tracking Codes Revised</title>
	<atom:link href="http://anomos.info/wp/2008/06/19/tracking-codes-revised/feed/" rel="self" type="application/rss+xml" />
	<link>http://anomos.info/wp/2008/06/19/tracking-codes-revised/</link>
	<description>The Anomos: Pseudonymous and Encrypted BitTorrent protocol</description>
	<pubDate>Wed, 07 Jan 2009 09:51:02 +0000</pubDate>
	<generator>http://wordpress.org/?v=2.7</generator>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
		<item>
		<title>By: John</title>
		<link>http://anomos.info/wp/2008/06/19/tracking-codes-revised/comment-page-1/#comment-5</link>
		<dc:creator>John</dc:creator>
		<pubDate>Wed, 02 Jul 2008 19:40:56 +0000</pubDate>
		<guid isPermaLink="false">http://anomos.info/wp/?p=19#comment-5</guid>
		<description>Thanks for the suggestion bh, although I didn't detail it in the post, we are using a padding scheme very similar to what you described. The encryption function E_peer generates an AES session key and uses that to bulk encrypt the rest of the tracking code. Each layer therefore looks something like this:
 {Session Key}[checksum, length, data, padding]
&#124;-------------------------160 bytes-------------------------------&#124;
where {} means that the data is encrypted with the peers RSA public key and [] means that it's encrypted with the AES session key. The [] section is padded so that its length modulo 32 is 0. The completed tracking code is padded out to a predefined size (most likely 1024 bytes), so that, after reading their part of the message, each peer can repad the message with random data to that length.</description>
		<content:encoded><![CDATA[<p>Thanks for the suggestion bh, although I didn&#8217;t detail it in the post, we are using a padding scheme very similar to what you described. The encryption function E_peer generates an AES session key and uses that to bulk encrypt the rest of the tracking code. Each layer therefore looks something like this:<br />
 {Session Key}[checksum, length, data, padding]<br />
|&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;-160 bytes&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;-|<br />
where {} means that the data is encrypted with the peers RSA public key and [] means that it&#8217;s encrypted with the AES session key. The [] section is padded so that its length modulo 32 is 0. The completed tracking code is padded out to a predefined size (most likely 1024 bytes), so that, after reading their part of the message, each peer can repad the message with random data to that length.</p>
]]></content:encoded>
	</item>
	<item>
		<title>By: bh</title>
		<link>http://anomos.info/wp/2008/06/19/tracking-codes-revised/comment-page-1/#comment-4</link>
		<dc:creator>bh</dc:creator>
		<pubDate>Tue, 24 Jun 2008 19:14:00 +0000</pubDate>
		<guid isPermaLink="false">http://anomos.info/wp/?p=19#comment-4</guid>
		<description>You're still leaking information about the path length since the path string monotonically decreases in length. If you na&#239;vely concatenate a pad, a participant can still infer the remaining length of the path.

Instead, I suggest that each participant attach a pseudo-random pad to the message before retransmission. When any recipient other than the last decrypts the message, the pad text will be indistinguishable from ciphertext intended for a subsequent recipient. The terminal recipient will be able to distinguish the original message from the pad text by means of some delimiter string.</description>
		<content:encoded><![CDATA[<p>You&#8217;re still leaking information about the path length since the path string monotonically decreases in length. If you na&iuml;vely concatenate a pad, a participant can still infer the remaining length of the path.</p>
<p>Instead, I suggest that each participant attach a pseudo-random pad to the message before retransmission. When any recipient other than the last decrypts the message, the pad text will be indistinguishable from ciphertext intended for a subsequent recipient. The terminal recipient will be able to distinguish the original message from the pad text by means of some delimiter string.</p>
]]></content:encoded>
	</item>
</channel>
</rss>
