updates
[crypto.git] / public_html / history.html
1 <html>
2 <style TYPE="text/css"><!-- A:link {text-decoration: none}A:visited{text-decoration:none}A:active{text-decoration:none}--></style>
3 <body bgcolor="#ffffff">
4 <p><br>
5 <a href="index.html"><img src="silc2.jpg" border=0></a>
6 <table width="70%" border="0" cellspacing="0" cellpadding="1"
7 align=center>
8 <tr>
9 <td>
10 <font face="Arial,Helvetica,Sans-serif">
11 <p>
12 <font size=4>
13 <h1>History</h1>
14 <p>
15 Even though SILC were released in summer 2000 to the public the idea and
16 the protocol itself is quite old.  I got the idea about SILC in its
17 current form in
18 the year 1996 and first lines of codes were written in early 1997.  This
19 release is now third rewrite of the SILC.  The very first version were
20 written in 1997 and it included SILC client and very very preliminary
21 SILC server.  The server actually weren't usable but the client looked
22 pretty much the same as it does now.  At that time the SILC also included
23 RSA implementation and 3DES implementation.  The random number generator
24 that exists in this current release is actually based on the RNG written
25 in 1997.  The RNG written in 1997, on the other hand, were based on
26 the SSH's random number generator.  The RNG has been rewritten twice
27 since the first version.
28 <p>
29 I stopped writing the SILC later in 1997 when I got busy at school and
30 in work.  The pause lasted several months.  The development resumed in
31 1998 when my friend (Juha Räsänen) and I implemented ElGamal algorithm.
32 I rewrote some other parts as well.  However, for the same reasons as
33 previously the development stopped again.  I resumed the development
34 later in 1998 by doing rewrite of the SILC in C++.  This was obviously 
35 a mistake but at that time it seemed like a good idea.  Again, in the 
36 winter 1999 I got very busy writing my thesis and was forced to stop the 
37 development again.  I also, started a new job in the spring.
38 <p>
39 Later, in 1999, I decided that this time I'm going to make it the right
40 way.  C++ was obviously a bad choice so I decided to fall back to plain
41 C language.  I also decided to do complete rewrite and started doing
42 more thorough planning of what the SILC actually should include.  I also
43 decided that this time it is going to kill me before I stop the 
44 development.  I started writing SILC in the weekends and actually 
45 everytime I had some spare time.  I also started a new job but I didn't
46 let that get to my way.  The result of this development effort is the
47 release now in public.
48 <p>
49 I've learned a lot by doing the SILC.  I guess, when I started it I wasn't
50 that good of a C programmer.  That alone was a reason why SILC hasn't
51 seen the day of light before now.  My programming style has also changed 
52 dramatically during these years.  Actually, it has changed couple times 
53 since this last rewrite as well.  However, the code style of current SILC 
54 release is quite consistent (actually the coding style SILC has been 
55 written now I've learned in my current job).
56 <p>
57 There is probably over 85% of new code in this third rewrite.  Rest has 
58 just been copied from the old versions and only minor changes has been
59 made (like changed function names and overall coding style).  I've 
60 preserved the dates of the old files (dating back to 1997) that has 
61 existed in some forms in the old versions.  There is a lot of new code but
62 already I see a lot that needs rewriting.  The development continues.
63 <p>
64 </td>
65 </tr>
66 </table>
67 </body>
68 </html>