summaryrefslogtreecommitdiffhomepage
path: root/ChangeLog.1
blob: 2fdae5a0faeaaad346aec475190cc071d07f115b (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
859
860
861
862
863
864
865
866
867
868
869
870
871
872
873
874
875
876
877
878
879
880
881
882
883
884
885
886
887
888
889
890
891
892
893
894
895
896
897
898
899
900
901
902
903
904
905
906
907
908
909
910
911
912
913
914
915
916
917
918
919
920
921
922
923
924
925
926
927
928
929
930
931
932
933
934
935
936
937
938
939
940
941
942
943
944
945
946
947
948
949
950
951
952
953
954
955
956
957
958
959
960
961
962
963
964
965
966
967
968
969
970
971
972
973
974
975
976
977
978
979
980
981
982
983
984
985
986
987
988
989
990
991
992
993
994
995
996
997
998
999
1000
1001
1002
1003
1004
1005
1006
1007
1008
1009
1010
1011
1012
1013
1014
1015
1016
1017
1018
1019
1020
1021
1022
1023
1024
1025
1026
1027
1028
1029
1030
1031
1032
1033
1034
1035
1036
1037
1038
1039
1040
1041
1042
1043
1044
1045
1046
1047
1048
1049
1050
1051
1052
1053
1054
1055
1056
1057
1058
1059
1060
1061
1062
1063
1064
1065
1066
1067
1068
1069
1070
1071
1072
1073
1074
1075
1076
1077
1078
1079
1080
1081
1082
1083
1084
1085
1086
1087
1088
1089
1090
1091
1092
1093
1094
1095
1096
1097
1098
1099
1100
1101
1102
1103
1104
1105
1106
1107
1108
1109
1110
1111
1112
1113
1114
1115
1116
1117
1118
1119
1120
1121
1122
1123
1124
1125
1126
1127
1128
1129
1130
1131
1132
1133
1134
1135
1136
1137
1138
1139
1140
1141
1142
1143
1144
1145
1146
1147
1148
1149
1150
1151
1152
1153
1154
1155
1156
1157
1158
1159
1160
1161
1162
1163
1164
1165
1166
1167
1168
1169
1170
1171
1172
1173
1174
1175
1176
1177
1178
1179
1180
1181
1182
1183
1184
1185
1186
1187
1188
1189
1190
1191
1192
1193
1194
1195
1196
1197
1198
1199
1200
1201
1202
1203
1204
1205
1206
1207
1208
1209
1210
1211
1212
1213
1214
1215
1216
1217
1218
1219
1220
1221
1222
1223
1224
1225
1226
1227
1228
1229
1230
1231
1232
1233
1234
1235
1236
1237
1238
1239
1240
1241
1242
1243
1244
1245
1246
1247
1248
1249
1250
1251
1252
1253
1254
1255
1256
1257
1258
1259
1260
1261
1262
1263
1264
1265
1266
1267
1268
1269
1270
1271
1272
1273
1274
1275
1276
1277
1278
1279
1280
1281
1282
1283
1284
1285
1286
1287
1288
1289
1290
1291
1292
1293
1294
1295
1296
1297
1298
1299
1300
1301
1302
1303
1304
1305
1306
1307
1308
1309
1310
1311
1312
1313
1314
1315
1316
1317
1318
1319
1320
1321
1322
1323
1324
1325
1326
1327
1328
1329
1330
1331
1332
1333
1334
1335
1336
1337
1338
1339
1340
1341
1342
1343
1344
1345
1346
1347
1348
1349
1350
1351
1352
1353
1354
1355
1356
1357
1358
1359
1360
1361
1362
1363
1364
1365
1366
1367
1368
1369
1370
1371
1372
1373
1374
1375
1376
1377
1378
1379
1380
1381
1382
1383
1384
1385
1386
1387
1388
1389
1390
1391
1392
1393
1394
1395
1396
1397
1398
1399
1400
1401
1402
1403
1404
1405
1406
1407
1408
1409
1410
1411
1412
1413
1414
1415
1416
1417
1418
1419
1420
1421
1422
1423
1424
1425
1426
1427
1428
1429
1430
1431
1432
1433
1434
1435
1436
1437
1438
1439
1440
1441
1442
1443
1444
1445
1446
1447
1448
1449
1450
1451
1452
1453
1454
1455
1456
1457
1458
1459
1460
1461
1462
1463
1464
1465
1466
1467
1468
1469
1470
1471
1472
1473
1474
1475
1476
1477
1478
1479
1480
1481
1482
1483
1484
1485
1486
1487
1488
1489
1490
1491
1492
1493
1494
1495
1496
1497
1498
1499
1500
1501
1502
1503
1504
1505
1506
1507
1508
1509
1510
1511
1512
1513
1514
1515
1516
1517
1518
1519
1520
1521
1522
1523
1524
1525
1526
1527
1528
1529
1530
1531
1532
1533
1534
1535
1536
1537
1538
1539
1540
1541
1542
1543
1544
1545
1546
1547
1548
1549
1550
1551
1552
1553
1554
1555
1556
1557
1558
1559
1560
1561
1562
1563
1564
1565
1566
1567
1568
1569
1570
1571
1572
1573
1574
1575
1576
1577
1578
1579
1580
1581
1582
1583
1584
1585
1586
1587
1588
1589
1590
1591
1592
1593
1594
1595
1596
1597
1598
1599
1600
1601
1602
1603
1604
1605
1606
1607
1608
1609
1610
1611
1612
1613
1614
1615
1616
1617
1618
1619
1620
1621
1622
1623
1624
1625
1626
1627
1628
1629
1630
1631
1632
1633
1634
1635
1636
1637
1638
1639
1640
1641
1642
1643
1644
1645
1646
1647
1648
1649
1650
1651
1652
1653
1654
1655
1656
1657
1658
1659
1660
1661
1662
1663
1664
1665
1666
1667
1668
1669
1670
1671
1672
1673
1674
1675
1676
1677
1678
1679
1680
1681
1682
1683
1684
1685
1686
1687
1688
1689
1690
1691
1692
1693
1694
1695
1696
1697
1698
1699
1700
1701
1702
1703
1704
1705
1706
1707
1708
1709
1710
1711
1712
1713
1714
1715
1716
1717
1718
1719
1720
1721
1722
1723
1724
1725
1726
1727
1728
1729
1730
1731
1732
1733
1734
1735
1736
1737
1738
1739
1740
1741
1742
1743
1744
1745
1746
1747
1748
1749
1750
1751
1752
1753
1754
1755
1756
1757
1758
1759
1760
1761
1762
1763
1764
1765
1766
1767
1768
1769
1770
1771
1772
1773
1774
1775
1776
1777
1778
1779
1780
1781
1782
1783
1784
1785
1786
1787
1788
1789
1790
1791
1792
1793
1794
1795
1796
1797
1798
1799
1800
1801
1802
1803
1804
1805
1806
1807
1808
1809
1810
1811
1812
1813
1814
1815
1816
1817
1818
1819
1820
1821
1822
1823
1824
1825
1826
1827
1828
1829
1830
1831
1832
1833
1834
1835
1836
1837
1838
1839
1840
1841
1842
1843
1844
1845
1846
1847
1848
1849
1850
1851
1852
1853
1854
1855
1856
1857
1858
1859
1860
1861
1862
1863
1864
1865
1866
1867
1868
1869
1870
1871
1872
1873
1874
1875
1876
1877
1878
1879
1880
1881
1882
1883
1884
1885
1886
1887
1888
1889
1890
1891
1892
1893
1894
1895
1896
1897
1898
1899
1900
1901
1902
1903
1904
1905
1906
1907
1908
1909
1910
1911
1912
1913
1914
1915
1916
1917
1918
1919
1920
1921
1922
1923
1924
1925
1926
1927
1928
1929
1930
1931
1932
1933
1934
1935
1936
1937
1938
1939
1940
1941
1942
1943
1944
1945
1946
1947
1948
1949
1950
1951
1952
1953
1954
1955
1956
1957
1958
1959
1960
1961
1962
1963
1964
1965
1966
1967
1968
1969
1970
1971
1972
1973
1974
1975
1976
1977
1978
1979
1980
1981
1982
1983
1984
1985
1986
1987
1988
1989
1990
1991
1992
1993
1994
1995
1996
1997
1998
1999
2000
2001
2002
2003
2004
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
2026
2027
2028
2029
2030
2031
2032
2033
2034
2035
2036
2037
2038
2039
2040
2041
2042
2043
2044
2045
2046
2047
2048
2049
2050
2051
2052
2053
2054
2055
2056
2057
2058
2059
2060
2061
2062
2063
2064
2065
2066
2067
2068
2069
2070
2071
2072
2073
2074
2075
2076
2077
2078
2079
2080
2081
2082
2083
2084
2085
2086
2087
2088
2089
2090
2091
2092
2093
2094
2095
2096
2097
2098
2099
2100
2101
2102
2103
2104
2105
2106
2107
2108
2109
2110
2111
2112
2113
2114
2115
2116
2117
2118
2119
2120
2121
2122
2123
2124
2125
2126
2127
2128
2129
2130
2131
2132
2133
2134
2135
2136
2137
2138
2139
2140
2141
2142
2143
2144
2145
2146
2147
2148
2149
2150
2151
2152
2153
2154
2155
2156
2157
2158
2159
2160
2161
2162
2163
2164
2165
2166
2167
2168
2169
2170
2171
2172
2173
2174
2175
2176
2177
2178
2179
2180
2181
2182
2183
2184
2185
2186
2187
2188
2189
2190
2191
2192
2193
2194
2195
2196
2197
2198
2199
2200
2201
2202
2203
2204
2205
2206
2207
2208
2209
2210
2211
2212
2213
2214
2215
2216
2217
2218
2219
2220
2221
2222
2223
2224
2225
2226
2227
2228
2229
2230
2231
2232
2233
2234
2235
2236
2237
2238
2239
2240
2241
2242
2243
2244
2245
2246
2247
2248
2249
2250
2251
2252
2253
2254
2255
2256
2257
2258
2259
2260
2261
2262
2263
2264
2265
2266
2267
2268
2269
2270
2271
2272
2273
2274
2275
2276
2277
2278
2279
2280
2281
2282
2283
2284
2285
2286
2287
2288
2289
2290
2291
2292
2293
2294
2295
2296
2297
2298
2299
2300
2301
2302
2303
2304
2305
2306
2307
2308
2309
2310
2311
2312
2313
2314
2315
2316
2317
2318
2319
2320
2321
2322
2323
2324
2325
2326
2327
2328
2329
2330
2331
2332
2333
2334
2335
2336
2337
2338
2339
2340
2341
2342
2343
2344
2345
2346
2347
2348
2349
2350
2351
2352
2353
2354
2355
2356
2357
2358
2359
2360
2361
2362
2363
2364
2365
2366
2367
2368
2369
2370
2371
2372
2373
2374
2375
2376
2377
2378
2379
2380
2381
2382
2383
2384
2385
2386
2387
2388
2389
2390
2391
2392
2393
2394
2395
2396
2397
2398
2399
2400
2401
2402
2403
2404
2405
2406
2407
2408
2409
2410
2411
2412
2413
2414
2415
2416
2417
2418
2419
2420
2421
2422
2423
2424
2425
2426
2427
2428
2429
2430
2431
2432
2433
2434
2435
2436
2437
2438
2439
2440
2441
2442
2443
2444
2445
2446
2447
2448
2449
2450
2451
2452
2453
2454
2455
2456
2457
2458
2459
2460
2461
2462
2463
2464
2465
2466
2467
2468
2469
2470
2471
2472
2473
2474
2475
2476
2477
2478
2479
2480
2481
2482
2483
2484
2485
2486
2487
2488
2489
2490
2491
2492
2493
2494
2495
2496
2497
2498
2499
2500
2501
2502
2503
2504
2505
2506
2507
2508
2509
2510
2511
2512
2513
2514
2515
2516
2517
2518
2519
2520
2521
2522
2523
2524
2525
2526
2527
2528
2529
2530
2531
2532
2533
2534
2535
2536
2537
2538
2539
2540
2541
2542
2543
2544
2545
2546
2547
2548
2549
2550
2551
2552
2553
2554
2555
2556
2557
2558
2559
2560
2561
2562
2563
2564
2565
2566
2567
2568
2569
2570
2571
2572
2573
2574
2575
2576
2577
2578
2579
2580
2581
2582
2583
2584
2585
2586
2587
2588
2589
2590
2591
2592
2593
2594
2595
2596
2597
2598
2599
2600
2601
2602
2603
2604
2605
2606
2607
2608
2609
2610
2611
2612
2613
2614
2615
2616
2617
2618
2619
2620
2621
2622
2623
2624
2625
2626
2627
2628
2629
2630
2631
2632
2633
2634
2635
2636
2637
2638
2639
2640
2641
2642
2643
2644
2645
2646
2647
2648
2649
2650
2651
2652
2653
2654
2655
2656
2657
2658
2659
2660
2661
2662
2663
2664
2665
2666
2667
2668
2669
2670
2671
2672
2673
2674
2675
2676
2677
2678
2679
2680
2681
2682
2683
2684
2685
2686
2687
2688
2689
2690
2691
2692
2693
2694
2695
2696
2697
2698
2699
2700
2701
2702
2703
2704
2705
2706
2707
2708
2709
2710
2711
2712
2713
2714
2715
2716
2717
2718
2719
2720
2721
2722
2723
2724
2725
2726
2727
2728
2729
2730
2731
2732
2733
2734
2735
2736
2737
2738
2739
2740
2741
2742
2743
2744
2745
2746
2747
2748
2749
2750
2751
2752
2753
2754
2755
2756
2757
2758
2759
2760
2761
2762
2763
2764
2765
2766
2767
2768
2769
2770
2771
2772
2773
2774
2775
2776
2777
2778
2779
2780
2781
2782
2783
2784
2785
2786
2787
2788
2789
2790
2791
2792
2793
2794
2795
2796
2797
2798
2799
2800
2801
2802
2803
2804
2805
2806
2807
2808
2809
2810
2811
2812
2813
2814
2815
2816
2817
2818
2819
2820
2821
2822
2823
2824
2825
2826
2827
2828
2829
2830
2831
2832
2833
2834
2835
2836
2837
2838
2839
2840
2841
2842
2843
2844
2845
2846
2847
2848
2849
2850
2851
2852
2853
2854
2855
2856
2857
2858
2859
2860
2861
2862
2863
2864
2865
2866
2867
2868
2869
2870
2871
2872
2873
2874
2875
2876
2877
2878
2879
2880
2881
2882
2883
2884
2885
2886
2887
2888
2889
2890
2891
2892
2893
2894
2895
2896
2897
2898
2899
2900
2901
2902
2903
2904
2905
2906
2907
2908
2909
2910
2911
2912
2913
2914
2915
2916
2917
2918
2919
2920
2921
2922
2923
2924
2925
2926
2927
2928
# do not edit -- automatically generated by arch changelog
# arch-tag: automatic-ChangeLog--robey@lag.net--2003-public/secsh--dev--1.0
#

2005-04-18 00:53:57 GMT	Robey Pointer <robey@lag.net>	patch-164

    Summary:
      fix some docs
    Revision:
      secsh--dev--1.0--patch-164

    remove some epydoc comments about fileno() being non-portable.

    modified files:
     paramiko/channel.py


2005-04-18 00:30:52 GMT	Robey Pointer <robey@lag.net>	patch-163

    Summary:
      add SFTPClient.close()
    Revision:
      secsh--dev--1.0--patch-163

    add SFTPClient.close() and add a simple little unit test for it.
    

    modified files:
     paramiko/sftp_client.py tests/test_sftp.py


2005-04-18 00:11:34 GMT	Robey Pointer <robey@lag.net>	patch-162

    Summary:
      avoid os.environ['HOME'] in the demos
    Revision:
      secsh--dev--1.0--patch-162

    avoid using os.environ['HOME'], which will never work on windows, and
    use os.path.expanduser() instead.  it's semi-moot because windows doesn't
    have a standard location for ssh files, but i think paramiko should set a
    good example anyway.

    modified files:
     demo.py demo_simple.py


2005-04-16 23:38:22 GMT	Robey Pointer <robey@lag.net>	patch-161

    Summary:
      integrated laptop work (test commit)
    Revision:
      secsh--dev--1.0--patch-161

    Patches applied:
    
     * robey@lag.net--2003-public-master-shake/secsh--dev--1.0--base-0
       tag of robey@lag.net--2003-public/secsh--dev--1.0--patch-160
    
     * robey@lag.net--2003-public-master-shake/secsh--dev--1.0--patch-1
       test commit
    
     * robey@lag.net--2003-public/secsh--dev--1.0--base-0
       initial import
    
     * robey@lag.net--2003-public/secsh--dev--1.0--patch-1
       no changes
    

    modified files:
     README paramiko/server.py

    new patches:
     robey@lag.net--2003-public-master-shake/secsh--dev--1.0--base-0
     robey@lag.net--2003-public-master-shake/secsh--dev--1.0--patch-1


2005-04-10 00:46:41 GMT	Robey Pointer <robey@lag.net>	patch-160

    Summary:
      1.3 marowak
    Revision:
      secsh--dev--1.0--patch-160

    bump version to 1.3 / marowak

    modified files:
     Makefile README paramiko/__init__.py paramiko/transport.py
     setup.py


2005-04-10 00:39:18 GMT	Robey Pointer <robey@lag.net>	patch-159

    Summary:
      clean up SFTPAttributes.__repr__
    Revision:
      secsh--dev--1.0--patch-159

    clean up SFTPAttributes repr() a bit.

    modified files:
     paramiko/sftp_attr.py


2005-04-10 00:13:54 GMT	Robey Pointer <robey@lag.net>	patch-158

    Summary:
      remove ChangeLog from MANIFEST.in
    Revision:
      secsh--dev--1.0--patch-158

    remove ChangeLog from the dist list.

    modified files:
     MANIFEST.in


2005-04-06 07:24:28 GMT	Robey Pointer <robey@lag.net>	patch-157

    Summary:
      change SubsystemHandler/SFTPServerInterface API
    Revision:
      secsh--dev--1.0--patch-157

    change the API of SubsystemHandler to accept a reference to the
    ServerInstance object during construction.  this will break all code
    that currently creates subsystem handlers (like sftp servers) -- sorry!
    
    lots of little doc fixups (mostly indenting).

    modified files:
     paramiko/server.py paramiko/sftp_server.py paramiko/sftp_si.py
     paramiko/transport.py tests/stub_sftp.py


2005-03-26 05:53:00 GMT	Robey Pointer <robey@lag.net>	patch-156

    Summary:
      rewrite channel pipes to work on windows
    Revision:
      secsh--dev--1.0--patch-156

    the pipe system i was using for simulating an os-level FD (for select) was
    retarded.  i realized this week that i could just use a single byte in the
    pipe to signal "data is ready" and not try to feed all incoming data thru
    the pipe -- and then i don't have to try to make the pipe non-blocking (which
    should make it work on windows).  a lot of duplicate code got removed and now
    it's all going thru the same code-path on read.
    
    there's still a slight penalty on incoming feeds and calling 'recv' when a
    pipe has been opened (by calling 'fileno'), but it's tiny.
    
    removed a bunch of documentation and comments about things not working on
    windows, since i think they probably do now.
    

    removed files:
     .arch-ids/demo_windows.py.id demo_windows.py

    modified files:
     MANIFEST.in README paramiko/channel.py


2005-03-25 20:06:56 GMT	Robey Pointer <robey@lag.net>	patch-155

    Summary:
      fix sending of large sftp packet sizes
    Revision:
      secsh--dev--1.0--patch-155

    fix a bug where packets larger than about 12KB would cause the session to
    die on platforms other than osx.  turns out that on most platforms, setting a
    socket timeout also causes timeouts to occur on writes (but not on osx).  so
    on a huge write, once the os buffers were full, paramiko would get a
    socket.timeout exception when writing, and bail.
    
    since the timeout is primarily so we can periodically poll to see if the
    session has been killed from elsewhere, do that on a timeout but otherwise
    continue trying to write.  large packet sizes (in sftp) should now work.

    modified files:
     paramiko/transport.py


2005-02-28 08:06:08 GMT	Robey Pointer <robey@lag.net>	patch-154

    Summary:
      even better 1.2 lapras
    Revision:
      secsh--dev--1.0--patch-154

    re-bump the version # to 1.2 (with a new date since i added more stuff).
    add 2005 to the copyright date in a bunch of files.
    

    modified files:
     Makefile README demo.py demo_server.py demo_simple.py
     demo_windows.py forward.py paramiko/__init__.py
     paramiko/auth_transport.py paramiko/ber.py paramiko/channel.py
     paramiko/common.py paramiko/dsskey.py paramiko/file.py
     paramiko/kex_gex.py paramiko/kex_group1.py
     paramiko/logging22.py paramiko/message.py paramiko/pkey.py
     paramiko/primes.py paramiko/rsakey.py paramiko/server.py
     paramiko/sftp.py paramiko/sftp_attr.py paramiko/sftp_client.py
     paramiko/sftp_handle.py paramiko/sftp_server.py
     paramiko/sftp_si.py paramiko/ssh_exception.py
     paramiko/transport.py paramiko/util.py setup.py test.py
     tests/loop.py tests/stub_sftp.py tests/test_file.py
     tests/test_kex.py tests/test_message.py tests/test_pkey.py
     tests/test_sftp.py tests/test_transport.py


2005-02-28 07:49:56 GMT	Robey Pointer <robey@lag.net>	patch-153

    Summary:
      tweak sftp_file write behavior on large blocks of data
    Revision:
      secsh--dev--1.0--patch-153

    BufferedFile.write() wasn't correctly dealing with the possibility that the
    underlying write might not write the entire data block at once (even though
    the docs said it would).  now that it's working, make sftp_file take
    advantage of it in order to chop up blocks larger than 32kB (the max allowed
    on sftp) and add a unit test for it.
    

    modified files:
     paramiko/file.py paramiko/sftp_file.py tests/test_sftp.py


2005-02-28 07:17:21 GMT	Robey Pointer <robey@lag.net>	patch-152

    Summary:
      little doc fixes
    Revision:
      secsh--dev--1.0--patch-152

    stupid little doc fixups that didn't fit with the other patches.

    modified files:
     paramiko/auth_transport.py tests/loop.py


2005-02-28 07:16:22 GMT	Robey Pointer <robey@lag.net>	patch-151

    Summary:
      fix race in transport thread startup
    Revision:
      secsh--dev--1.0--patch-151

    set active=True from the methods that start the main transport thread, right
    before actually starting the thread.  this avoids a race where the main
    thread could be started, but the original thread could wake up from the
    event.wait(0.1) before the new thread actually set the transport active.
    impossible, you say?  no machines so slow exist?  au contraire, my sad
    little linux box faced this problem earlier today.
    

    modified files:
     paramiko/transport.py


2005-02-28 07:14:11 GMT	Robey Pointer <robey@lag.net>	patch-150

    Summary:
      when combining stderr with stdout on a channel, merge the buffers too
    Revision:
      secsh--dev--1.0--patch-150

    when turning on combine-stderr mode on a channel, grab the channel lock and
    feed any existing stderr buffer into the normal buffer.  this should help
    applications (and my unit tests) avoid races between data coming in over
    stderr and setting combine-stderr.
    
    _send_eof is now slightly safer too, although i don't think that really fixed
    anything.  it just makes me feel better.

    modified files:
     paramiko/channel.py


2005-02-28 07:09:02 GMT	Robey Pointer <robey@lag.net>	patch-149

    Summary:
      add thread ids to logs
    Revision:
      secsh--dev--1.0--patch-149

    add a logging filter that reports the thread-id of the logger, and use
    that for all paramiko logging.  since thread-local stuff didn't appear
    until python 2.4, i hacked up my own little version to assign incrementing
    numbers to threads as they log.
    

    modified files:
     paramiko/channel.py paramiko/sftp.py paramiko/sftp_client.py
     paramiko/sftp_server.py paramiko/transport.py paramiko/util.py


2005-02-26 21:12:43 GMT	Robey Pointer <robey@lag.net>	patch-148

    Summary:
      forgot to check in stub_sftp
    Revision:
      secsh--dev--1.0--patch-148

    yikes! don't forget to check this in: needed for unit tests.

    new files:
     tests/.arch-ids/stub_sftp.py.id tests/stub_sftp.py


2005-02-26 21:11:04 GMT	Robey Pointer <robey@lag.net>	patch-147

    Summary:
      1.2 (lapras)
    Revision:
      secsh--dev--1.0--patch-147

    bump version stuff to 1.2 / lapras.

    modified files:
     Makefile README paramiko/__init__.py paramiko/transport.py
     setup.py


2005-02-15 15:48:47 GMT	Robey Pointer <robey@lag.net>	patch-146

    Summary:
      raise better exception on empty key
    Revision:
      secsh--dev--1.0--patch-146

    raise a clearer exception when trying to create an empty key.
    

    modified files:
     README paramiko/dsskey.py paramiko/rsakey.py
     tests/test_transport.py


2005-02-15 15:47:02 GMT	Robey Pointer <robey@lag.net>	patch-145

    Summary:
      add methods for sending/receiving a channel's exit status
    Revision:
      secsh--dev--1.0--patch-145

    track a channel's exit status and provide a method (recv_exit_status) to
    block waiting for it to arrive.  also provide a convenience method for
    servers to send it (send_exit_status).  add shutdown_read and shutdown_write.
    fix a bug in sending window change requests.
    

    modified files:
     README paramiko/channel.py paramiko/transport.py


2005-02-06 23:32:22 GMT	Robey Pointer <robey@lag.net>	patch-144

    Summary:
      fix docs
    Revision:
      secsh--dev--1.0--patch-144

    clean up some of the docs.
    

    modified files:
     README paramiko/pkey.py paramiko/sftp_attr.py


2005-02-06 23:30:40 GMT	Robey Pointer <robey@lag.net>	patch-143

    Summary:
      fix an sftp unit test
    Revision:
      secsh--dev--1.0--patch-143

    fix one of the sftp unit tests to actually work.
    

    modified files:
     tests/test_sftp.py


2005-02-05 07:45:20 GMT	Robey Pointer <robey@lag.net>	patch-142

    Summary:
      fix windows sample script's HOME
    Revision:
      secsh--dev--1.0--patch-142

    fix the HOME environ var to work on windows too.

    modified files:
     demo_windows.py


2005-01-25 05:17:55 GMT	Robey Pointer <robey@lag.net>	patch-141

    Summary:
      misc logging fixes
    Revision:
      secsh--dev--1.0--patch-141

    change the level of some log messages so interesting stuff gets logged at
    info instead of debug.  fix an oops where channels defaulted to being in
    ultra debug mode, and make this mode depend on a new Transport method:
    "set_hexdump".
    

    modified files:
     paramiko/auth_transport.py paramiko/channel.py
     paramiko/sftp.py paramiko/sftp_client.py
     paramiko/sftp_server.py paramiko/transport.py


2005-01-17 10:09:09 GMT	Robey Pointer <robey@lag.net>	patch-140

    Summary:
      more flexible logging
    Revision:
      secsh--dev--1.0--patch-140

    some tweaks to make channels etc follow the logger setting of their parent
    transport, so that setting the log channel for a paramiko transport will
    cause all sub-logging to branch out from that channel.
    
    also, close all open file handles when the sftp server ends.
    

    modified files:
     paramiko/channel.py paramiko/sftp_attr.py
     paramiko/sftp_client.py paramiko/sftp_handle.py
     paramiko/sftp_server.py paramiko/transport.py


2005-01-16 21:03:15 GMT	Robey Pointer <robey@lag.net>	patch-139

    Summary:
      make loopback sftp tests the default
    Revision:
      secsh--dev--1.0--patch-139

    change the unit tests to default to always running the sftp tests locally,
    and make a -R option to force the tests to run against a remote server.
    the tests seem to work fine locally, and it helps test out server mode,
    even though there's a danger that they could get isolated from reality
    and only test that paramiko can talk to itself.
    

    modified files:
     test.py


2005-01-16 20:14:07 GMT	Robey Pointer <robey@lag.net>	patch-138

    Summary:
      doc fixups
    Revision:
      secsh--dev--1.0--patch-138

    little doc fixups that i did obsessively on the train one morning.

    modified files:
     paramiko/file.py


2005-01-09 05:27:07 GMT	Robey Pointer <robey@lag.net>	patch-137

    Summary:
      added listdir_attr()
    Revision:
      secsh--dev--1.0--patch-137

    add SFTPClient.listdir_attr() to fetch a list of files & their attributes,
    instead of just their filenames.  artur piwko would find this useful.
    

    modified files:
     paramiko/sftp_attr.py paramiko/sftp_client.py


2004-12-19 19:56:48 GMT	Robey Pointer <robey@lag.net>	patch-136

    Summary:
      loopback sftp test
    Revision:
      secsh--dev--1.0--patch-136

    add ability to turn off more tests, and a secret (for now) -X option to do
    the sftp tests via loopback socket.  added another symlink sftp test to see
    what happens with absolute symlinks.
    

    modified files:
     test.py tests/test_sftp.py


2004-12-19 19:50:00 GMT	Robey Pointer <robey@lag.net>	patch-135

    Summary:
      more sftp cleanup
    Revision:
      secsh--dev--1.0--patch-135

    oops, this should've been part of the last patch.
    

    modified files:
     paramiko/sftp_si.py


2004-12-19 19:43:27 GMT	Robey Pointer <robey@lag.net>	patch-134

    Summary:
      cleanup & docs in sftp
    Revision:
      secsh--dev--1.0--patch-134

    add some more docs to SFTPHandle, and give a default implementation for
    close() that's usually right.  add a flush() to the default implementation
    of write().  document that symlink's args in the sftp protocol are out of
    order (the spec is wrong).
    

    modified files:
     paramiko/sftp_handle.py paramiko/sftp_server.py


2004-12-13 07:32:14 GMT	Robey Pointer <robey@lag.net>	patch-133

    Summary:
      unit test madness
    Revision:
      secsh--dev--1.0--patch-133

    add some more testy bits and fix up some other bits.
    

    modified files:
     tests/test_transport.py


2004-12-13 07:31:01 GMT	Robey Pointer <robey@lag.net>	patch-132

    Summary:
      oops (continued)
    Revision:
      secsh--dev--1.0--patch-132

    er, part 2 of that.
    

    modified files:
     paramiko/server.py


2004-12-13 07:29:38 GMT	Robey Pointer <robey@lag.net>	patch-131

    Summary:
      move check_global_request
    Revision:
      secsh--dev--1.0--patch-131

    move check_global_request into the server interface -- i missed it during
    the initial move (oops).
    

    modified files:
     paramiko/transport.py


2004-12-13 07:27:39 GMT	Robey Pointer <robey@lag.net>	patch-130

    Summary:
      small fixups
    Revision:
      secsh--dev--1.0--patch-130

    move _wait_for_send_window into the right place in Channel.  remove outdated
    note from auth_transport.  fix download url in setup.py.
    
    

    modified files:
     paramiko/auth_transport.py paramiko/channel.py setup.py


2004-12-12 09:58:40 GMT	Robey Pointer <robey@lag.net>	patch-129

    Summary:
      1.1 (kabuto)
    Revision:
      secsh--dev--1.0--patch-129

    edit various files to bump the version to 1.1.
    also fix to point to the new url.
    

    modified files:
     Makefile README paramiko/__init__.py paramiko/transport.py
     setup.py


2004-12-12 09:38:24 GMT	Robey Pointer <robey@lag.net>	patch-128

    Summary:
      more unit tests
    Revision:
      secsh--dev--1.0--patch-128

    added unit tests for multi-part auth, exec_command, and invoke_shell.
    

    modified files:
     tests/test_transport.py


2004-12-12 09:32:17 GMT	Robey Pointer <robey@lag.net>	patch-127

    Summary:
      doc fixups
    Revision:
      secsh--dev--1.0--patch-127

    fix some typos in sftp_client docs
    

    modified files:
     paramiko/sftp_client.py


2004-12-12 09:25:15 GMT	Robey Pointer <robey@lag.net>	patch-126

    Summary:
      server support for stderr & exec_command
    Revision:
      secsh--dev--1.0--patch-126

    for the server side of my stderr blunder, add send_stderr & sendall_stderr,
    and make the sending side of makefile_stderr work correctly.
    
    also, call check_channel_exec_request on a server object for exec requests
    on a channel.
    

    modified files:
     paramiko/channel.py paramiko/server.py


2004-12-12 09:16:03 GMT	Robey Pointer <robey@lag.net>	patch-125

    Summary:
      add client-side multi-part auth support
    Revision:
      secsh--dev--1.0--patch-125

    added support for multi-part authentication (even though nobody supports it
    that i've seen).  on a successful "partial" auth, the auth_* method will
    return a list of acceptable means to continue authenticating.
    

    modified files:
     paramiko/auth_transport.py paramiko/ssh_exception.py


2004-12-11 03:44:33 GMT	Robey Pointer <robey@lag.net>	patch-124

    Summary:
      docs fixup
    Revision:
      secsh--dev--1.0--patch-124

    fix a comment typo, and add @since designators to a couple of new methods.
    

    modified files:
     paramiko/channel.py paramiko/sftp_server.py


2004-12-11 03:43:18 GMT	Robey Pointer <robey@lag.net>	patch-123

    Summary:
      clean up authentication
    Revision:
      secsh--dev--1.0--patch-123

    add new exception "BadAuthenticationType", which is raised when auth fails
    because your auth type (password or public-key) isn't valid on the server.
    
    used this as an excuse to clean up auth_password and auth_publickey so their
    'event' arg is optional, and if missing, they block until auth is finished,
    raising an exception on error.
    
    also, don't close the session on failed auth -- the server may let you try
    again.
    
    added some test cases for failed auth.
    

    modified files:
     paramiko/__init__.py paramiko/auth_transport.py
     paramiko/ssh_exception.py paramiko/transport.py
     tests/test_transport.py


2004-12-10 08:30:44 GMT	Robey Pointer <robey@lag.net>	patch-122

    Summary:
      symlink, readlink
    Revision:
      secsh--dev--1.0--patch-122

    add support for symlink command, and finish support for readlink.  (i guess
    i started readlink a while ago but forgot to add the right method to the
    SFTPServerInterface class.)
    

    modified files:
     paramiko/sftp_server.py paramiko/sftp_si.py tests/test_sftp.py


2004-12-10 08:27:43 GMT	Robey Pointer <robey@lag.net>	patch-121

    Summary:
      other part of that last patch
    Revision:
      secsh--dev--1.0--patch-121

    oops, forgot this part.

    modified files:
     paramiko/transport.py


2004-12-10 08:25:28 GMT	Robey Pointer <robey@lag.net>	patch-120

    Summary:
      add stderr support methods
    Revision:
      secsh--dev--1.0--patch-120

    big embarrassment: i didn't read the ssh2 docs close enough, and all this
    time paramiko wasn't handling "extended_data" packets, which contain stderr
    output.
    
    so now, several new functions: recv_stderr_ready() and recv_stderr() to
    mirror recv_ready() and recv(), and set_combined_stderr() to force stderr
    to be combined into stdout.  also, makefile_stderr() to create a fake file
    object to represent stderr.
    

    modified files:
     paramiko/channel.py


2004-12-10 07:55:33 GMT	Robey Pointer <robey@lag.net>	patch-119

    Summary:
      reformat README
    Revision:
      secsh--dev--1.0--patch-119

    reformatted the README to a slightly smaller margin, just because.
    

    modified files:
     README


2004-12-09 04:15:12 GMT	Robey Pointer <robey@lag.net>	patch-118

    Summary:
      fix SFTPFile gettimeout/settimeout
    Revision:
      secsh--dev--1.0--patch-118

    i don't think the gettimeout/settimeout calls on SFTPFile ever worked.
    also, simplify the implementation of _get_size() since it's nearly
    identical to stat().
    

    modified files:
     paramiko/sftp_file.py


2004-12-09 02:42:36 GMT	Robey Pointer <robey@lag.net>	patch-117

    Summary:
      readme comments
    Revision:
      secsh--dev--1.0--patch-117

    add another fixme to the readme

    modified files:
     README


2004-11-26 22:07:31 GMT	Robey Pointer <robey@lag.net>	patch-116

    Summary:
      doc fixups
    Revision:
      secsh--dev--1.0--patch-116

    explain "recv_ready" better, and add debug descriptions for the kex codes.
    

    modified files:
     README paramiko/channel.py paramiko/common.py


2004-11-25 19:39:34 GMT	Robey Pointer <robey@lag.net>	patch-115

    Summary:
      fix CONNECTION_FAILED_CODE
    Revision:
      secsh--dev--1.0--patch-115

    oops, fix typo in channel request failed.

    modified files:
     paramiko/transport.py


2004-11-22 07:40:39 GMT	Robey Pointer <robey@lag.net>	patch-114

    Summary:
      fix typo in channel
    Revision:
      secsh--dev--1.0--patch-114

    fix typo that alain found: pipd_wfd -> pipe_wfd.
    

    modified files:
     paramiko/channel.py


2004-11-22 07:27:21 GMT	Robey Pointer <robey@lag.net>	patch-113

    Summary:
      sftp server support!
    Revision:
      secsh--dev--1.0--patch-113

    finally check in sftp_handle (file handle abstraction), sftp_si (server
    interface), and sftp_server (server implementation) -- all of which make
    a roughly 90% implementation of server-side sftp.
    
    

    new files:
     paramiko/.arch-ids/sftp_handle.py.id
     paramiko/.arch-ids/sftp_server.py.id
     paramiko/.arch-ids/sftp_si.py.id paramiko/sftp_handle.py
     paramiko/sftp_server.py paramiko/sftp_si.py

    modified files:
     README demo_windows.py paramiko/__init__.py


2004-11-22 07:07:08 GMT	Robey Pointer <robey@lag.net>	patch-112

    Summary:
      add finish_subsystem()
    Revision:
      secsh--dev--1.0--patch-112

    when a SubsystemHandler is being decomissioned (the client has closed the
    channel or transport, or the socket went away), make a callback to let the
    handler do any shutdown it needs to.
    

    modified files:
     paramiko/server.py


2004-11-22 07:04:31 GMT	Robey Pointer <robey@lag.net>	patch-111

    Summary:
      fix extremely unlikely channel counter wrapping
    Revision:
      secsh--dev--1.0--patch-111

    Transport's channel counter can overflow after 4 billion some channels are
    created.  make it wrap back around after 16 million instead.  also allow the
    logging channel to be set manually.  fix some comments elsewhere.
    

    modified files:
     paramiko/channel.py paramiko/primes.py paramiko/transport.py


2004-11-22 07:01:43 GMT	Robey Pointer <robey@lag.net>	patch-110

    Summary:
      fix Transport.get_username() to work in server mode too
    Revision:
      secsh--dev--1.0--patch-110

    whenever i split the 'username' field into username and auth_username,
    i guess that made get_username() stop working for server mode (because the
    username was stored in a different field).  this should fix it.

    modified files:
     paramiko/auth_transport.py


2004-11-07 03:10:53 GMT	Robey Pointer <robey@lag.net>	patch-109

    Summary:
      v1.0 (jigglypuff)
    Revision:
      secsh--dev--1.0--patch-109

    bump all the version numbers up to 1.0 (jigglypuff).

    modified files:
     Makefile README paramiko/__init__.py paramiko/transport.py
     setup.py


2004-11-07 02:51:42 GMT	Robey Pointer <robey@lag.net>	patch-108

    Summary:
      add filename to SFTPAttributes
    Revision:
      secsh--dev--1.0--patch-108

    add filename to the attributes stored in an SFTPAttributes object.

    modified files:
     paramiko/sftp_attr.py


2004-11-07 02:31:48 GMT	Robey Pointer <robey@lag.net>	patch-107

    Summary:
      fix kex_gex
    Revision:
      secsh--dev--1.0--patch-107

    fix kex_gex (group-exchange key exchange) to, *cough*, work again, and also
    layout kex_group1 a little more sanely.

    modified files:
     paramiko/kex_gex.py paramiko/kex_group1.py


2004-11-07 02:29:54 GMT	Robey Pointer <robey@lag.net>	patch-106

    Summary:
      fix chmod +x on demo_windows.py
    Revision:
      secsh--dev--1.0--patch-106

    forgot to make demo_windows +x


2004-11-07 02:29:20 GMT	Robey Pointer <robey@lag.net>	patch-105

    Summary:
      move ChangeLog
    Revision:
      secsh--dev--1.0--patch-105

    move ChangeLog out of the way because tla can autogenerate any useful
    ChangeLog.
    

    renamed files:
     .arch-ids/ChangeLog.id
       ==> .arch-ids/ChangeLog-old.id
     ChangeLog
       ==> ChangeLog-old


2004-11-07 02:28:33 GMT	Robey Pointer <robey@lag.net>	patch-104

    Summary:
      fix location of SFTPError
    Revision:
      secsh--dev--1.0--patch-104

    fix location of SFTPError.

    modified files:
     paramiko/__init__.py paramiko/sftp_client.py


2004-11-07 02:17:18 GMT	Robey Pointer <robey@lag.net>	patch-103

    Summary:
      rename sftp constants
    Revision:
      secsh--dev--1.0--patch-103

    replace oddly named sftp constants (FX_OK for example) with names that make
    a bit more sense when sober (SFTP_OK).

    modified files:
     paramiko/__init__.py paramiko/sftp.py paramiko/sftp_client.py


2004-11-07 02:08:11 GMT	Robey Pointer <robey@lag.net>	patch-102

    Summary:
      add key exchange tests + 1 more sftp test
    Revision:
      secsh--dev--1.0--patch-102

    add test suite for key-exchange protocols, since i apparently broke the
    "gex" protocol recently and never noticed.  also add an sftp unit test for
    mkdir/rmdir.

    new files:
     tests/.arch-ids/test_kex.py.id tests/test_kex.py

    modified files:
     test.py tests/test_sftp.py


2004-11-07 02:00:50 GMT	Robey Pointer <robey@lag.net>	patch-101

    Summary:
      remove old demo keys
    Revision:
      secsh--dev--1.0--patch-101

    the keys are in tests/ now.

    removed files:
     .arch-ids/demo_dss_key.id .arch-ids/demo_rsa_key.id
     demo_dss_key demo_rsa_key


2004-11-06 20:32:08 GMT	Robey Pointer <robey@lag.net>	patch-100

    Summary:
      don't forget demo_windows.py
    Revision:
      secsh--dev--1.0--patch-100

    update MANIFEST.in to include demo_windows.py and not include the demo
    keys (they're in tests/ now).  clean up the README to explain the demo
    scripts better now, since there are so many of them.  then fix up the
    demo scripts to look in tests/ for the keys.
    
    demo_windows.py doesn't need to call get_pty() (in fact, i think that's
    blowing openssh's mind) and was executing the wrong command.
    

    modified files:
     MANIFEST.in README demo_server.py demo_simple.py
     demo_windows.py


2004-11-01 07:07:48 GMT	Robey Pointer <robey@lag.net>	patch-99

    Summary:
      use getpass
    Revision:
      secsh--dev--1.0--patch-99

    convert raw_input to getpass as suggested many weeks ago.

    modified files:
     forward.py


2004-11-01 03:54:01 GMT	Robey Pointer <robey@lag.net>	patch-98

    Summary:
      don't unlink a Channel until the server closes it too
    Revision:
      secsh--dev--1.0--patch-98

    when close()'ing a Channel, don't immediately unlink it from the Transport.
    instead, wait for the server to send a close message.
    
    this should fix a bug where doing close() on an EOF'd channel would cause
    the entire transport to be killed, because the server would send an
    'exit-status' and 'close' message for a channel that we no longer had a
    record of.
    

    modified files:
     paramiko/channel.py


2004-11-01 03:43:28 GMT	Robey Pointer <robey@lag.net>	patch-97

    Summary:
      better debugging, improve subsytem handler
    Revision:
      secsh--dev--1.0--patch-97

    add a list of ssh packet names for debugging.  improve the server-mode
    subsystem handler so it can take extra parameters (list or keyword) and
    pass them to the subsystem constructor.  remove a misleading comment
    about rekeying (which was already implemented).
    

    modified files:
     paramiko/common.py paramiko/server.py paramiko/transport.py


2004-11-01 03:37:42 GMT	Robey Pointer <robey@lag.net>	patch-96

    Summary:
      remove key.valid check
    Revision:
      secsh--dev--1.0--patch-96

    oops!  'key.valid' no longer works -- catch the SSHException instead, and log
    it.
    

    modified files:
     paramiko/auth_transport.py


2004-10-23 07:36:23 GMT	Robey Pointer <robey@lag.net>	patch-95

    Summary:
      ivysaur 0.9
    Revision:
      secsh--dev--1.0--patch-95

    update ivysaur release date, and add the list of changes to the README
    file.
    

    modified files:
     Makefile README paramiko/__init__.py


2004-10-20 16:52:51 GMT	Robey Pointer <robey@lag.net>	patch-94

    Summary:
      start testing Transport
    Revision:
      secsh--dev--1.0--patch-94

    the beginnings of tests for Transport.  only the bare minimum is there right
    now.
    
    also started doc'ing things up to ivysaur.

    new files:
     .arch-ids/demo_windows.py.id demo_windows.py
     tests/.arch-ids/loop.py.id
     tests/.arch-ids/test_transport.py.id tests/loop.py
     tests/test_transport.py

    modified files:
     Makefile README paramiko/__init__.py setup.py test.py


2004-10-18 04:54:27 GMT	Robey Pointer <robey@lag.net>	patch-93

    Summary:
      switch Transport.connect() to using a Pkey object for the host key
    Revision:
      secsh--dev--1.0--patch-93

    i suddenly realized that passing "hostkeytype" and "hostkey" as strings to
    Transport.connect() was pretty silly since i went to all the effort of making
    a class specifically for holding keys.  so Transport.connect() now just takes
    host-key argument: "hostkey" as a PKey object.
    
    updated the demos to use PKey objects when reading the host key file, and to
    use the new "hostkey" argument.
    

    modified files:
     demo.py demo_simple.py paramiko/pkey.py paramiko/transport.py


2004-09-25 22:07:59 GMT	Robey Pointer <robey@lag.net>	patch-92

    Summary:
      add rsa/dss key object unit tests
    Revision:
      secsh--dev--1.0--patch-92

    add tests for rsa/dss key objects -- yay!
    

    new files:
     tests/.arch-ids/test_dss.key.id
     tests/.arch-ids/test_pkey.py.id
     tests/.arch-ids/test_rsa.key.id tests/test_dss.key
     tests/test_pkey.py tests/test_rsa.key


2004-09-25 22:03:48 GMT	Robey Pointer <robey@lag.net>	patch-91

    Summary:
      fix test.py to use options instead of env vars, sftp tests default off
    Revision:
      secsh--dev--1.0--patch-91

    fix up the test framework so that the sftp unit tests aren't always run (you
    have to ask for them explicitly) and they take their configuration from
    command-line options.  they still require a remote server.

    modified files:
     test.py tests/test_sftp.py


2004-09-25 21:58:11 GMT	Robey Pointer <robey@lag.net>	patch-90

    Summary:
      fix __init__
    Revision:
      secsh--dev--1.0--patch-90

    fix __init__ to export BufferedFile and randpool, and to catch up with the
    changes from a week or 2 ago where sftp_attr & friends were split off.

    modified files:
     paramiko/__init__.py


2004-09-25 21:47:19 GMT	Robey Pointer <robey@lag.net>	patch-89

    Summary:
      fix some Transport docs
    Revision:
      secsh--dev--1.0--patch-89

    document that Transport also would like close() and settimeout() to exist
    on the socket-like object passed to the constructor.

    modified files:
     paramiko/transport.py


2004-09-25 21:32:53 GMT	Robey Pointer <robey@lag.net>	patch-88

    Summary:
      add Message.rewind()
    Revision:
      secsh--dev--1.0--patch-88

    add rewind() method to Message, which just resets the pointer so you can
    start reading from the beginning again.  this is useful for some tests.

    modified files:
     paramiko/message.py tests/test_message.py


2004-09-25 21:28:23 GMT	Robey Pointer <robey@lag.net>	patch-87

    Summary:
      clean up pkey interface
    Revision:
      secsh--dev--1.0--patch-87

    change the pkey interface so that it's no longer possible to have a pkey
    that doesn't represent a valid key.  (ie: no more "blank" key objects.)
    also add "get_bits" and "can_sign" methods to determine the key bit length
    and whether it can sign things (contains the "private parts") respectively.

    modified files:
     paramiko/dsskey.py paramiko/pkey.py paramiko/rsakey.py


2004-09-11 21:01:32 GMT	Robey Pointer <robey@lag.net>	patch-86

    Summary:
      unit tests for Message
    Revision:
      secsh--dev--1.0--patch-86

    spanking new unit tests for Message.  i'm trying to fix the embarrassment
    of having so little of paramiko testable.  next up is Transport!

    new files:
     tests/.arch-ids/test_message.py.id tests/test_message.py


2004-09-11 20:56:01 GMT	Robey Pointer <robey@lag.net>	patch-85

    Summary:
      move SFTPFile and SFTPAttributes into their own files
    Revision:
      secsh--dev--1.0--patch-85

    move SFTPFile and SFTPAttributes into their own files.

    new files:
     paramiko/.arch-ids/sftp_attr.py.id
     paramiko/.arch-ids/sftp_file.py.id paramiko/sftp_attr.py
     paramiko/sftp_file.py

    modified files:
     paramiko/sftp.py paramiko/sftp_client.py


2004-09-11 20:50:39 GMT	Robey Pointer <robey@lag.net>	patch-84

    Summary:
      add sftp.normalize
    Revision:
      secsh--dev--1.0--patch-84

    kevin c. dorff pointed out that it would be nice to expose a way to
    determine the server's "current working directory", so this new method
    (normalize) directly maps to REALPATH.

    modified files:
     paramiko/sftp_client.py


2004-09-11 20:43:09 GMT	Robey Pointer <robey@lag.net>	patch-83

    Summary:
      tweak Message.add() in the key exchanges
    Revision:
      secsh--dev--1.0--patch-83

    use the new Message.add() behavior to make a little code here much easier
    to read.

    modified files:
     paramiko/kex_gex.py paramiko/kex_group1.py


2004-09-11 20:40:08 GMT	Robey Pointer <robey@lag.net>	patch-82

    Summary:
      doc fixes
    Revision:
      secsh--dev--1.0--patch-82

    fix "string" -> "str" in types when documenting BufferedFile.

    modified files:
     paramiko/file.py


2004-09-11 20:37:59 GMT	Robey Pointer <robey@lag.net>	patch-81

    Summary:
      more unit tests
    Revision:
      secsh--dev--1.0--patch-81

    add test for BufferedFile.read(-1) and sftp.normalize().

    modified files:
     tests/test_file.py tests/test_sftp.py


2004-09-11 20:36:49 GMT	Robey Pointer <robey@lag.net>	patch-80

    Summary:
      move SubsystemHandler to server.py
    Revision:
      secsh--dev--1.0--patch-80

    move SubsystemHandler into server.py where it makes more sense (it's part of
    the server interface).
    
    also fix up paramiko's "version string" used in ssh2 negotiation to stop
    saying "pyssh" and start saying "paramiko". :)

    modified files:
     paramiko/server.py paramiko/transport.py


2004-09-11 20:35:19 GMT	Robey Pointer <robey@lag.net>	patch-79

    Summary:
      Message.add() can take many args
    Revision:
      secsh--dev--1.0--patch-79

    a bit of cleanup to Message:  add() can now take any number of params, and
    will add them all in order (using type guessing).

    modified files:
     paramiko/message.py


2004-09-09 01:36:45 GMT	Robey Pointer <robey@lag.net>	patch-78

    Summary:
      fix rbuffer -> _rbuffer in 3 places i missed
    Revision:
      secsh--dev--1.0--patch-78

    fix 3 places where "rbuffer" hadn't been converted to "_rbuffer".  thanks to
    kevin c. dorff for the bug report.

    modified files:
     paramiko/file.py


2004-09-07 06:56:49 GMT	Robey Pointer <robey@lag.net>	patch-77

    Summary:
      docs for SubsystemHandler
    Revision:
      secsh--dev--1.0--patch-77

    add documentation to constructor for SubsystemHandler.

    modified files:
     paramiko/transport.py


2004-09-07 06:54:31 GMT	Robey Pointer <robey@lag.net>	patch-76

    Summary:
      add sftp_client.py
    Revision:
      secsh--dev--1.0--patch-76

    i retardedly forgot to import this file a few days ago: it's the split-out
    client mode for sftp.  it now also has some changes to adapt it to the
    improved SFTPAttributes object API.

    new files:
     paramiko/.arch-ids/sftp_client.py.id paramiko/sftp_client.py


2004-09-07 06:51:03 GMT	Robey Pointer <robey@lag.net>	patch-75

    Summary:
      clean up SFTPAttributes
    Revision:
      secsh--dev--1.0--patch-75

    add english descriptions to the FX_* error codes of sftp.  clean up (and
    document) SFTPAttributes since it's exported now, and make it simple to
    generate one from a python os.stat object.  make "_pythonize" the default --
    that is, just use the same field names as python does for os.stat.  (i'm not
    sure why i didn't do it that way in the first place; probably ignorance.)
    also add str() method that converts the SFTPAttributes into a string suitable
    for use in ls (used in an obscure way in sftp servers).

    modified files:
     paramiko/sftp.py


2004-09-07 06:45:53 GMT	Robey Pointer <robey@lag.net>	patch-74

    Summary:
      note pycrypto 2.0 in README
    Revision:
      secsh--dev--1.0--patch-74

    update the README to note that pycrypto 2.0 works (i just tried it).  also
    fix the name from pyCrypt back to pycrypto -- that project is having trouble
    making up its mind about naming. :)

    modified files:
     README


2004-09-05 07:44:03 GMT	Robey Pointer <robey@lag.net>	patch-73

    Summary:
      split sftp into sftp, sftp_client; renamed SFTP -> SFTPClient
    Revision:
      secsh--dev--1.0--patch-73

    add sftp_client file, and split out the common code (sftp) from stuff specific
    to client mode (sftp_client).  renamed SFTP class to SFTPClient, but left an
    alias so old code will still work.
    
    renamed a bunch of sftp constants now that they're better hidden from epydoc.

    modified files:
     README paramiko/__init__.py paramiko/sftp.py


2004-09-05 07:41:45 GMT	Robey Pointer <robey@lag.net>	patch-72

    Summary:
      some framework for adding subsystem handlers in server mode
    Revision:
      secsh--dev--1.0--patch-72

    you can now register a subsystem with a Transport by passing in the name
    (like "sftp") and a class (like a hypothetical SFTPServer).  the default
    ServerInterface.check_channel_request_subsystem now checks this table in
    Transport, and if it finds a match, it creates a new thread for the handler
    and calls into it.  a new class SubsystemHandler is added for this purpose
    (to be subclassed).

    modified files:
     paramiko/server.py paramiko/transport.py


2004-09-05 07:37:40 GMT	Robey Pointer <robey@lag.net>	patch-71

    Summary:
      remove redundant 'auth_complete' member
    Revision:
      secsh--dev--1.0--patch-71

    remove the redundant 'auth_complete' field and just use 'authenticated' for
    both client and server mode.  this makes the repr() string look correct in
    server mode instead of always claiming that the transport is un-auth'd.

    modified files:
     paramiko/auth_transport.py


2004-09-03 22:39:20 GMT	Robey Pointer <robey@lag.net>	patch-70

    Summary:
      clean up server interface; no longer need to subclass Channel
    Revision:
      secsh--dev--1.0--patch-70

    - export AUTH_*, OPEN_FAILED_*, and the new OPEN_SUCCEEDED into the paramiko
      namespace instead of making people dig into paramiko.Transport.AUTH_* etc.
    - move all of the check_* methods from Channel to ServerInterface so apps
      don't need to subclass Channel anymore just to run an ssh server
    - ServerInterface.check_channel_request() returns an error code now, not a
      new Channel object
    - fix demo_server.py to follow all these changes
    - fix a bunch of places where i used "string" in docstrings but meant "str"
    - added Channel.get_id()

    modified files:
     README demo_server.py paramiko/__init__.py
     paramiko/auth_transport.py paramiko/channel.py
     paramiko/common.py paramiko/server.py paramiko/sftp.py
     paramiko/transport.py


2004-08-31 02:44:56 GMT	Robey Pointer <robey@lag.net>	patch-69

    Summary:
      clean up SecurityOptions
    Revision:
      secsh--dev--1.0--patch-69

    the preferences are now tuples in Transport, and passed as tuples out of
    SecurityOptions, so that the options can't be modified without setting them
    back to the options field again.  the algorithm lists in Transport are used
    to validate the fields.

    modified files:
     paramiko/transport.py


2004-08-30 20:22:10 GMT	Robey Pointer <robey@lag.net>	patch-68

    Summary:
      added Transport.get_security_options()
    Revision:
      secsh--dev--1.0--patch-68

    just something i wanted to play with:
    added Transport.get_security_options() which returns a SecurityOptions object.
    this object is a kind of proxy for the 4 "preferred_*" fields in Transport,
    and lets me avoid exposing those fields directly in case i change my mind
    later about how they should be stored.
    
    added some docs to Channel explaining that the request methods now return
    True/False, and fixed up docs in a few other places.

    modified files:
     paramiko/__init__.py paramiko/channel.py paramiko/server.py
     paramiko/sftp.py paramiko/transport.py


2004-08-28 04:21:12 GMT	Robey Pointer <robey@lag.net>	patch-67

    Summary:
      replay patch 63 (missing channel changes)
    Revision:
      secsh--dev--1.0--patch-67

    i'm still getting the hang of tla/arch, obviously.
    
    replay patch 63, which was meant to be part of the later mega-patch, but
    apparently when i reversed it, i lost it entirely.

    modified files:
     paramiko/channel.py


2004-08-27 00:57:40 GMT	Robey Pointer <robey@lag.net>	patch-66

    Summary:
      new ServerInterface class, outbound rekey works, etc.
    Revision:
      secsh--dev--1.0--patch-66

    a bunch of changes that i'm too lazy to split out into individual patches:
    * all the server overrides from transport.py have been moved into a separate
      class ServerInterface, so server code doesn't have to subclass the whole
      paramiko library
    * updated demo_server to subclass ServerInterface
    * when re-keying during a session, block other messages until the new keys
      are activated (openssh doensn't like any other traffic during a rekey)
    * re-key when outbound limits are tripped too (was only counting inbound
      traffic)
    * don't log scary things on EOF
    

    new files:
     paramiko/.arch-ids/server.py.id paramiko/server.py

    modified files:
     README demo_server.py paramiko/__init__.py
     paramiko/auth_transport.py paramiko/transport.py


2004-08-27 00:28:33 GMT	Robey Pointer <robey@lag.net>	patch-65

    Summary:
      add settimeout/gettimeout/setblocking, some bugfixes.
    Revision:
      secsh--dev--1.0--patch-65

    hide the command and response codes in sftp so they aren't exported.
    add settimeout/gettimeout/setblocking that just wrap calls to the underlying
    socket or channel.  fix _read_all to not catch timeout exceptions.
    

    modified files:
     paramiko/sftp.py


2004-08-27 00:26:35 GMT	Robey Pointer <robey@lag.net>	patch-64

    Summary:
      reverse messed-up patch
    Revision:
      secsh--dev--1.0--patch-64

    Patches applied:
    
     * robey@lag.net--2003-public/secsh--dev--1.0--base-0
       initial import
    
     * robey@lag.net--2003-public/secsh--dev--1.0--patch-1
       no changes
    

    modified files:
     paramiko/channel.py {arch}/=tagging-method


2004-08-27 00:06:42 GMT	Robey Pointer <robey@lag.net>	patch-63

    Summary:
      add settimeout/gettimeout/setblocking, some bugfixes.
    Revision:
      secsh--dev--1.0--patch-63

    hide the command and response codes in sftp so they aren't exported.
    add settimeout/gettimeout/setblocking that just wrap calls to the underlying
    socket or channel.  fix _read_all to not catch timeout exceptions.

    modified files:
     paramiko/channel.py


2004-06-27 20:14:15 GMT	Robey Pointer <robey@lag.net>	patch-62

    Summary:
      version -> horsea
    Revision:
      secsh--dev--1.0--patch-62

    up version to horsea.

    modified files:
     Makefile README paramiko/__init__.py setup.py
     {arch}/secsh/secsh--dev/secsh--dev--1.0/robey@lag.net--2003-public/patch-log/patch-1


2004-06-10 18:12:00 GMT	Robey Pointer <robey@lag.net>	patch-61

    Summary:
      no more Foobar
    Revision:
      secsh--dev--1.0--patch-61

    fix "Foobar" to be "Paramiko" in the one place i missed it in all the gpl
    headers.  sigh. :)

    modified files:
     paramiko/__init__.py paramiko/auth_transport.py
     paramiko/ber.py paramiko/common.py paramiko/dsskey.py
     paramiko/kex_gex.py paramiko/kex_group1.py
     paramiko/logging22.py paramiko/message.py paramiko/pkey.py
     paramiko/primes.py paramiko/rsakey.py
     paramiko/ssh_exception.py paramiko/util.py test.py


2004-06-10 18:08:50 GMT	Robey Pointer <robey@lag.net>	patch-60

    Summary:
      limit read/write requests to 32KB, advertise 32KB max packet size
    Revision:
      secsh--dev--1.0--patch-60

    one of the unit tests was failing because the openssh sftp server was dropping
    the connection without any error.  turns out they have a maximum allowed write
    size (possibly around 64KB).  the sftp rfcs have a small hint that some servers
    may drop read/write requests of greater than 32KB.
    
    so, all reads are limited to 32KB, and all writes > 32KB are now chopped up
    and sent in 32KB chunks.  this seems to keep openssh happy.
    
    also, we now advertise 32KB max packet size instead of 8KB (the speed
    improves a lot), and log when we read/write a packet.  and sftp files are
    flushed on seek.

    modified files:
     paramiko/sftp.py paramiko/transport.py


2004-06-10 18:02:13 GMT	Robey Pointer <robey@lag.net>	patch-59

    Summary:
      speed up parts of BufferedFile
    Revision:
      secsh--dev--1.0--patch-59

    BufferedFile uses cStringIO for the write buffer now (i don't actually notice
    any speed difference so this might revert later) and the default buffer size
    has been upped from 1KB to 8KB.
    
    when scanning for linefeeds (when writing to a line-buffered file), only scan
    the newly-written bytes, since we know all the previously buffered data is
    linefeed-free.  this was the #1 slowdown on the 1MB-file unit test.
    
    also, limit the buffering on line-buffered files to whatever the default
    buffer size is.  there's no reason to buffer 1MB waiting for a linefeed.

    modified files:
     paramiko/file.py


2004-06-10 17:55:17 GMT	Robey Pointer <robey@lag.net>	patch-58

    Summary:
      some Channel fixes for max packet size & blocking on zero window
    Revision:
      secsh--dev--1.0--patch-58

    some clean-ups and fixes to channels:
    * when send() is blocked on a zero-width window, check that the channel is
      still open.  this was causing some lockups.
    * set a lower bound to the "maximum packet size" we accept from the remote
      host.  if they tell us anything less than 1KB, assume they meant 1KB.  (it's
      not reasonable to fragment below that.)
    * leave a little padding instead of cutting right up to the maximum packet
      size: some space will be taken up by protocol overhead.
    * turn off some of the debug log lines unless "ultra_debug" is on (nobody
      cares about the feed info)
    

    modified files:
     paramiko/channel.py


2004-06-10 17:35:30 GMT	Robey Pointer <robey@lag.net>	patch-57

    Summary:
      more unit tests
    Revision:
      secsh--dev--1.0--patch-57

    add a unit test for sending a large (1MB) file with line buffering but no
    linefeeds (this triggered several bugs and inefficiencies), and another test
    to verify that the write buffer is flushed on seek.

    modified files:
     tests/test_file.py tests/test_sftp.py


2004-05-31 23:48:10 GMT	Robey Pointer <robey@lag.net>	patch-56

    Summary:
      add forward.py demo script; bump to gyarados
    Revision:
      secsh--dev--1.0--patch-56

    add a demo script to show how to do local port forwarding.
    
    add gyarados to all the docs and bump the version number everywhere.

    new files:
     .arch-ids/forward.py.id forward.py

    modified files:
     MANIFEST.in Makefile README paramiko/__init__.py setup.py


2004-05-29 18:58:11 GMT	Robey Pointer <robey@lag.net>	patch-55

    Summary:
      add an sftp unit test for making 100 files
    Revision:
      secsh--dev--1.0--patch-55

    create 100 files on the remote server, set their mode with chmod, then verify
    that they're all there and contain the right data.  valeriy is reporting that
    sometimes he's getting stuck after 20 and though i'm not seeing it, i want to
    add a test to try to pin it down.

    modified files:
     tests/test_sftp.py


2004-05-29 18:56:10 GMT	Robey Pointer <robey@lag.net>	patch-54

    Summary:
      add direct-tcpip ability to open_channel
    Revision:
      secsh--dev--1.0--patch-54

    open_channel can now be given a dest_addr and src_addr, which are filled in
    if the channel type is "forwarded-tcpip" or "direct-tcpip".  these channel
    types are used in remote & local port forwarding, respectively.  i've only
    tested "direct-tcpip" but i think if one works, they both should work.
    
    also fixed a bug in connect where it was still assuming the old meaning for
    get_remove_server_key() (oops!) and changed the sense of a send() failure
    from <= 0 to < 0 since it may be possible for send() to return 0 and it not
    be an EOF error.

    modified files:
     paramiko/transport.py


2004-05-29 18:48:23 GMT	Robey Pointer <robey@lag.net>	patch-53

    Summary:
      add note about utf8 encodings
    Revision:
      secsh--dev--1.0--patch-53

    add info to the README about what to do if python complains about missing
    encodings.  veleriy pogrebitskiy ran into this and had advice.

    modified files:
     README


2004-05-17 07:41:50 GMT	Robey Pointer <robey@lag.net>	patch-52

    Summary:
      fix deadlock in closing a channel
    Revision:
      secsh--dev--1.0--patch-52

    closing a channel would enter an odd codepath where the lock was grabbed,
    some stuff was done, then another function was called where the lock was
    grabbed again.  unfortunately python locks aren't monitors so this would
    deadlock.  instead, make the smaller function lock-free with an explicit
    notice that you must be holding the lock before calling.

    modified files:
     paramiko/channel.py


2004-05-17 00:43:43 GMT	Robey Pointer <robey@lag.net>	patch-51

    Summary:
      fix utf8, raise packet size, log exceptions, be more lax with sfp servers
    Revision:
      secsh--dev--1.0--patch-51

    explicitly import utf8 encodings for "freezing" (and also because not all
    platforms come with utf8, apparently).  raise the max acceptable packet size
    to 8kB, cuz 2kB was too low.  log exceptions at error level instead of debug
    level.  and don't reject older sftp servers.

    modified files:
     paramiko/auth_transport.py paramiko/sftp.py
     paramiko/transport.py


2004-04-23 22:55:16 GMT	Robey Pointer <robey@lag.net>	patch-50

    Summary:
      fearow date and last-minute fixes
    Revision:
      secsh--dev--1.0--patch-50

    update release date of fearow to 23apr.  fix channel._set_closed() to grab
    the lock before notifying the in/out buffers that the channel is closed.
    try roger's trick for finding the home folder on windows.

    modified files:
     Makefile README paramiko/__init__.py paramiko/channel.py
     paramiko/common.py


2004-04-08 06:31:08 GMT	Robey Pointer <robey@lag.net>	patch-49

    Summary:
      fix doc typos
    Revision:
      secsh--dev--1.0--patch-49


    modified files:
     paramiko/dsskey.py paramiko/rsakey.py paramiko/transport.py


2004-04-08 05:48:16 GMT	Robey Pointer <robey@lag.net>	patch-48

    Summary:
      set version number to fearow
    Revision:
      secsh--dev--1.0--patch-48

    set version number to fearow.

    modified files:
     Makefile README paramiko/__init__.py setup.py


2004-04-08 05:12:20 GMT	Robey Pointer <robey@lag.net>	patch-47

    Summary:
      add socket.timeout for py22
    Revision:
      secsh--dev--1.0--patch-47

    oops, forgot this vital part of the py22 patches.  roger binns sent me a
    code patch that included this snip.

    modified files:
     paramiko/common.py


2004-04-07 16:05:48 GMT	Robey Pointer <robey@lag.net>	patch-46

    Summary:
      README update notes
    Revision:
      secsh--dev--1.0--patch-46

    added notes on what's new, what to watch out for in py22.  added a "since:
    fearow" to all the relevant API calls that are new.

    modified files:
     README paramiko/auth_transport.py paramiko/dsskey.py
     paramiko/pkey.py paramiko/rsakey.py paramiko/transport.py


2004-04-07 15:52:07 GMT	Robey Pointer <robey@lag.net>	patch-45

    Summary:
      add set_keepalive()
    Revision:
      secsh--dev--1.0--patch-45

    add set_keepalive() to set an automatic keepalive mechanism.  (while waiting
    for a packet on a connection, we periodically check if it's time to send a
    keepalive packet.)

    modified files:
     paramiko/transport.py


2004-04-07 06:07:29 GMT	Robey Pointer <robey@lag.net>	patch-44

    Summary:
      add get_username() method for remembering who you auth'd as
    Revision:
      secsh--dev--1.0--patch-44

    add get_username() method for remembering who you auth'd as.  also, fix these
    bugs:
    * "continue" auth response counted as a failure (in server mode).
    * try to import 'logging' in py22 before falling back to the fake logger,
      in case they have a backported version of 'logger'
    * raise the right exception when told to read a private key from a file that
      isn't a private key file
    * tell channels to close when the transport dies

    modified files:
     paramiko/auth_transport.py paramiko/channel.py
     paramiko/common.py paramiko/pkey.py paramiko/transport.py


2004-04-06 22:03:21 GMT	Robey Pointer <robey@lag.net>	patch-43

    Summary:
      fix encrypted private key files
    Revision:
      secsh--dev--1.0--patch-43

    the random byte padding on private key files' BER data was confusing openssh,
    so switch to null-byte padding, which is slightly less secure but works with
    crappy old openssh.  also, enforce the mode when writing the private key
    file.  we really really want it to be 0600.  (python seems to ignore the
    mode normally.)

    modified files:
     paramiko/pkey.py


2004-04-06 08:16:02 GMT	Robey Pointer <robey@lag.net>	patch-42

    Summary:
      support py22, more or less
    Revision:
      secsh--dev--1.0--patch-42

    add roger binns' patches for supporting python 2.2.  i hedged a bit on the
    logging stuff and just added some trickery to let logging be stubbed out for
    python 2.2.  this changed a lot of import statements but i managed to avoid
    hacking at any of the existing logging.
    
    socket timeouts are required for the threads to notice when they've been
    deactivated.  worked around it by using the 'select' module on py22.
    
    also fixed the sftp unit tests to cope with a password-protected private key.

    new files:
     paramiko/.arch-ids/logging22.py.id paramiko/logging22.py

    modified files:
     README demo.py demo_server.py demo_simple.py
     paramiko/__init__.py paramiko/auth_transport.py
     paramiko/channel.py paramiko/common.py paramiko/kex_gex.py
     paramiko/kex_group1.py paramiko/message.py paramiko/sftp.py
     paramiko/transport.py paramiko/util.py tests/test_sftp.py


2004-04-05 22:32:03 GMT	Robey Pointer <robey@lag.net>	patch-41

    Summary:
      make get_remote_server_key() return a PKey object
    Revision:
      secsh--dev--1.0--patch-41

    a good suggestion from roger binns: make get_remote_server_key() just return
    a pkey object instead of a tuple of strings.  all the strings can be extracted
    from the pkey object, as well as other potentially useful things.

    modified files:
     demo.py paramiko/transport.py


2004-04-05 19:36:40 GMT	Robey Pointer <robey@lag.net>	patch-40

    Summary:
      add dss key generation too, and fix some bugs
    Revision:
      secsh--dev--1.0--patch-40

    added the ability to generate dss keys and write private dss key files,
    similar to rsa.  in the process, fixed a couple of bugs with ber encoding
    and writing password-encrypted key files.  the key has to be padded to the
    iblock size of the cipher -- it's very difficult to determine how the others
    do this, so i just add random bytes to the end.
    
    fixed the simple demo to use Transport's (host, port) constructor for
    simplicity, and fixed a bug where the standard demo's DSS login wouldn't
    work.
    
    also, move the common logfile setup crap into util so all the demos can just
    call that one.

    modified files:
     demo.py demo_simple.py paramiko/ber.py paramiko/dsskey.py
     paramiko/pkey.py paramiko/rsakey.py paramiko/util.py


2004-04-05 10:37:18 GMT	Robey Pointer <robey@lag.net>	patch-39

    Summary:
      add global request mechanism
    Revision:
      secsh--dev--1.0--patch-39

    add transport.global_request() to make a global-style request (usually an
    extension to the protocol -- like keepalives) and handle requests from the
    remote host.  incoming requests are now handled and responded to correctly,
    which should make openssh-style keepalives work.  (before, we would silently
    ignore them, which was wrong.)

    modified files:
     paramiko/common.py paramiko/message.py paramiko/transport.py


2004-04-05 10:24:33 GMT	Robey Pointer <robey@lag.net>	patch-38

    Summary:
      add common.py file
    Revision:
      secsh--dev--1.0--patch-38

    missing from previous change because tla doesn't like to add files in some
    situations. (frown)
    

    new files:
     paramiko/.arch-ids/common.py.id paramiko/common.py


2004-04-05 10:16:31 GMT	Robey Pointer <robey@lag.net>	patch-37

    Summary:
      can now generate rsa keys (not dss yet)
    Revision:
      secsh--dev--1.0--patch-37

    added functionality to ber to create ber streams.  added some common methods
    to PKey to allow dumping the key to base64 (the format used by openssh for
    public key files and host key lists), and a factory for creating a key from
    a private key file, and a common way to save private keys.  RSAKey luckily
    didn't have to change that much.
    
    also added a factory method to RSAKey to generate a new key.
    

    modified files:
     paramiko/ber.py paramiko/pkey.py paramiko/rsakey.py


2004-04-05 10:12:59 GMT	Robey Pointer <robey@lag.net>	patch-36

    Summary:
      add common.py for commonly used constants and globals
    Revision:
      secsh--dev--1.0--patch-36

    common.py now stores the constants and globals.
    lots of renaming because of this.

    modified files:
     paramiko/auth_transport.py paramiko/channel.py
     paramiko/kex_gex.py paramiko/kex_group1.py
     paramiko/transport.py paramiko/util.py


2004-04-02 02:41:43 GMT	Robey Pointer <robey@lag.net>	patch-35

    Summary:
      add send_ignore
    Revision:
      secsh--dev--1.0--patch-35

    add send_ignore() call to allow for sending garbage ignored packets to the
    remote side.

    modified files:
     paramiko/transport.py


2004-03-16 07:33:09 GMT	Robey Pointer <robey@lag.net>	patch-34

    Summary:
      fix some arcana in unpacking private keys
    Revision:
      secsh--dev--1.0--patch-34

    "!= type([])" is a pretty obscure way to say it.  let's try "is not list"
    which is a lot more readable.
    
    (mostly this is a test to make sure tla is working okay on my laptop.)

    modified files:
     paramiko/dsskey.py paramiko/rsakey.py


2004-03-09 01:09:17 GMT	Robey Pointer <robey@lag.net>	patch-33

    Summary:
      include tests in manifest
    Revision:
      secsh--dev--1.0--patch-33

    include the tests in the manifest for dist, and remove some outdated notes in
    NOTES about the exported API (this is doc'd wayyy better in epydoc now).

    modified files:
     MANIFEST.in NOTES


2004-03-08 17:54:19 GMT	Robey Pointer <robey@lag.net>	patch-32

    Summary:
      add unit tests
    Revision:
      secsh--dev--1.0--patch-32

    add unit tests for BufferedFile and SFTP (it's a start).  remove the demo sftp
    client because it was 99% copied from the other demos, which makes it kinda
    confusing.  the unit tests are a much better example.

    new files:
     .arch-ids/test.py.id test.py tests/.arch-ids/=id
     tests/.arch-ids/test_file.py.id
     tests/.arch-ids/test_sftp.py.id tests/test_file.py
     tests/test_sftp.py

    removed files:
     .arch-ids/demo_sftp.py.id demo_sftp.py

    new directories:
     tests tests/.arch-ids


2004-03-08 17:52:25 GMT	Robey Pointer <robey@lag.net>	patch-31

    Summary:
      bump version number to eevee
    Revision:
      secsh--dev--1.0--patch-31

    bump the version number to eevee in a few places and talk about the unit
    tests.

    modified files:
     Makefile README paramiko/__init__.py setup.py


2004-03-08 17:50:49 GMT	Robey Pointer <robey@lag.net>	patch-30

    Summary:
      finish up client sftp support
    Revision:
      secsh--dev--1.0--patch-30

    added 'stat' to SFTPFile and SFTP, documented 'open' and 'listdir', and added
    'rmdir', 'lstat', 'symlink', 'chmod', 'chown', 'utime', 'readlink'.
    
    turned off ultra debugging now that the unit tests are all working.

    modified files:
     paramiko/sftp.py


2004-03-08 17:45:44 GMT	Robey Pointer <robey@lag.net>	patch-29

    Summary:
      fix some docs and BufferedFile.readline
    Revision:
      secsh--dev--1.0--patch-29

    fix some documentation and fix readline()'s universal newline support to
    always return strings ending with '\n', regardless of how they were in the
    original file.  (this is an obvious feature of python's universal newline
    support that i somehow missed before.)

    modified files:
     paramiko/file.py paramiko/message.py


2004-03-08 09:47:47 GMT	Robey Pointer <robey@lag.net>	patch-28

    Summary:
      fix lingering thread bug
    Revision:
      secsh--dev--1.0--patch-28

    this bug has been in there forever and i could never figure out a workaround
    till now.
    
    when the python interpreter exits, it doesn't necessarily destroy the
    remaining objects or call __del__ on anything, and it will lock up until all
    threads finish running.  how the threads are supposed to notice the exiting
    interpreter has always been sort of a mystery to me.
    
    tonight i figured out how to use the 'atexit' module to register a handler
    that runs when the interpreter exits.  now we keep a list of active threads
    and ask them all to exit on shutdown.  no more going to another shell to
    kill -9 python!  yeah!!

    modified files:
     paramiko/transport.py


2004-03-04 08:21:45 GMT	Robey Pointer <robey@lag.net>	patch-27

    Summary:
      add BufferedFile abstraction
    Revision:
      secsh--dev--1.0--patch-27

    SFTP client mode is mostly functional.  there are probably still some bugs
    but most of the operations on "file" objects have survived my simple tests.
    
    BufferedFile wraps a simpler stream in something that looks like a python
    file (and can even handle seeking if the stream underneath supports it).
    it's meant to be subclassed.  most of it is ripped out of what used to be
    ChannelFile so i can reuse it for sftp -- ChannelFile is now tiny.
    
    SFTP and Message are now exported.
    
    fixed util.format_binary_line to not quote spaces.

    new files:
     .arch-ids/demo_sftp.py.id demo_sftp.py
     paramiko/.arch-ids/file.py.id paramiko/.arch-ids/sftp.py.id
     paramiko/file.py paramiko/sftp.py

    modified files:
     paramiko/__init__.py paramiko/channel.py paramiko/message.py
     paramiko/util.py


2004-01-27 02:04:59 GMT	Robey Pointer <robey@lag.net>	patch-26

    Summary:
      Transport constructor can take hostname or address tuple
    Revision:
      secsh--dev--1.0--patch-26

    part of an ongoing attempt to make "simple" versions of some of the API calls,
    so you can do common-case operations with just a few calls:
    
    Transport's constructor will now let you pass in a string or tuple instead
    of a socket-like object.  if you pass in a string, it assumes the string is
    a hostname (with optional ":port" segment) and turns that into an address
    tuple.  if you pass in a tuple, it assumes it's an address tuple.  in both
    cases, it then creates a socket, connects to the given address, and then
    continues as if that was the socket passed in.
    
    the idea being that you can call Transport('example.com') and it will do
    the right thing.

    modified files:
     paramiko/transport.py


2004-01-27 02:00:19 GMT	Robey Pointer <robey@lag.net>	patch-25

    Summary:
      pkey no longer raises binascii.Error
    Revision:
      secsh--dev--1.0--patch-25

    catch binascii.Error in the private key decoder and convert it into an
    SSHException.  there's no reason people should have to care that it was a
    decoding error vs. any of the other million things that could be wrong in
    a corrupt key file.

    modified files:
     paramiko/pkey.py


2004-01-27 01:45:44 GMT	Robey Pointer <robey@lag.net>	patch-24

    Summary:
      document more of Message; add get_int64
    Revision:
      secsh--dev--1.0--patch-24

    all of the get_* methods are now documented, but there's a bit more to do.
    get_int64 added for eventual sftp support.

    modified files:
     paramiko/message.py


2004-01-04 10:33:05 GMT	Robey Pointer <robey@lag.net>	patch-23

    Summary:
      quick doc fix.
    Revision:
      secsh--dev--1.0--patch-23

    fix broken cross-link in kex_gex docs.

    modified files:
     paramiko/kex_gex.py


2004-01-04 10:26:00 GMT	Robey Pointer <robey@lag.net>	patch-22

    Summary:
      fix MANIFEST.in, change version numbers to 0.9-doduo, fix LPGL notices
    Revision:
      secsh--dev--1.0--patch-22

    fixed MANIFEST.in to include the demo scripts, LICENSE, and ChangeLog.
    upped everything to version 0.9-doduo.
    
    fixed the copyright notice, and added the LGPL banner to the top of every
    python file.

    modified files:
     MANIFEST.in Makefile NOTES README paramiko/__init__.py
     paramiko/auth_transport.py paramiko/ber.py paramiko/channel.py
     paramiko/dsskey.py paramiko/kex_gex.py paramiko/kex_group1.py
     paramiko/message.py paramiko/pkey.py paramiko/primes.py
     paramiko/rsakey.py paramiko/ssh_exception.py
     paramiko/transport.py paramiko/util.py setup.py


2004-01-04 10:07:35 GMT	Robey Pointer <robey@lag.net>	patch-21

    Summary:
      MANIFEST -> MANIFEST.in, fix setup.py.
    Revision:
      secsh--dev--1.0--patch-21

    out with MANIFEST, in with MANIFEST.in.

    new files:
     .arch-ids/MANIFEST.in.id MANIFEST.in

    removed files:
     .arch-ids/MANIFEST.id MANIFEST

    modified files:
     setup.py


2004-01-04 09:29:13 GMT	Robey Pointer <robey@lag.net>	patch-20

    Summary:
      more docs, and password-protected key files can now be read
    Revision:
      secsh--dev--1.0--patch-20

    lots more documentation, some of it moved out of the README file, which is
    now much smaller and less rambling.
    
    repr(Transport) now reports the number of bits used in the cipher.
    
    cleaned up BER to use util functions, and throw a proper exception (the new
    BERException) on error.  it doesn't ever have to be a full BER decoder, but
    it can at least comb its hair and tuck in its shirt.
    
    lots of stuff added to PKey.read_private_key_file so it can try to decode
    password-protected key files.  right now it only understands "DES-EDE3-CBC"
    format, but this is the only format i've seen openssh make so far.  if the
    key is password-protected, but no password was given, a new exception
    (PasswordRequiredException) is raised so an outer layer can ask for a password
    and try again.

    modified files:
     README demo.py demo_server.py paramiko/__init__.py
     paramiko/auth_transport.py paramiko/ber.py paramiko/channel.py
     paramiko/dsskey.py paramiko/pkey.py paramiko/primes.py
     paramiko/rsakey.py paramiko/ssh_exception.py
     paramiko/transport.py paramiko/util.py


2003-12-31 06:31:43 GMT	Robey Pointer <robey@lag.net>	patch-19

    Summary:
      renamed auth_key -> auth_publickey; more docs.
    Revision:
      secsh--dev--1.0--patch-19

    renamed Transport.auth_key to auth_publickey for consistency.  and lots more
    documentation.

    modified files:
     README demo.py demo_server.py paramiko/__init__.py
     paramiko/auth_transport.py paramiko/transport.py


2003-12-30 22:24:21 GMT	Robey Pointer <robey@lag.net>	patch-18

    Summary:
      added public-key support to server mode, more docs
    Revision:
      secsh--dev--1.0--patch-18

    added public-key support to server mode (it can now verify a client signature)
    and added a demo of that to the demo_server.py script (user_rsa_key).  in the
    process, cleaned up the API of PKey so that now it only has to know about
    signing and verifying ssh2 blobs, and can be hashed and compared with other
    keys (comparing & hashing only the public parts of the key).  keys can also
    be created from strings now too.
    
    some more documentation and hiding private methods.

    new files:
     .arch-ids/user_rsa_key.id .arch-ids/user_rsa_key.pub.id
     user_rsa_key user_rsa_key.pub

    modified files:
     Makefile demo_server.py paramiko/__init__.py
     paramiko/auth_transport.py paramiko/dsskey.py
     paramiko/kex_gex.py paramiko/kex_group1.py paramiko/pkey.py
     paramiko/rsakey.py paramiko/transport.py


2003-12-30 07:18:20 GMT	Robey Pointer <robey@lag.net>	patch-17

    Summary:
      lots more documentation, and added Transport.connect()
    Revision:
      secsh--dev--1.0--patch-17

    renamed demo_host_key to demo_rsa_key.  moved changelog to a separate file,
    and indicated that future changelog entries should be fetched from tla.
    tried to clean up "__all__" in a way that makes epydoc still work.
    
    added lots more documentation, and renamed many methods and vars to hide
    them as private non-exported API.
    
    Transport's ModulusPack is now a static member, so it only has to be loaded
    once, and can then be used by any future Transport object.
    
    added Transport.connect(), which tries to wrap all the SSH2 negotiation and
    authentication into one method.  you should be able to create a Transport,
    call connect(), and then create channels.

    new files:
     .arch-ids/ChangeLog.id .arch-ids/demo_simple.py.id ChangeLog
     demo_simple.py paramiko/.arch-ids/pkey.py.id paramiko/pkey.py

    removed files:
     .arch-ids/paramiko.py.id paramiko.py

    modified files:
     Makefile NOTES README demo.py demo_server.py
     paramiko/__init__.py paramiko/auth_transport.py
     paramiko/channel.py paramiko/dsskey.py paramiko/kex_gex.py
     paramiko/kex_group1.py paramiko/rsakey.py
     paramiko/transport.py setup.py {arch}/=tagging-method

    renamed files:
     .arch-ids/demo_host_key.id
       ==> .arch-ids/demo_rsa_key.id
     demo_host_key
       ==> demo_rsa_key


2003-12-28 03:20:42 GMT	Robey Pointer <robey@lag.net>	patch-16

    Summary:
      hook up server-side kex-gex; add more documentation
    Revision:
      secsh--dev--1.0--patch-16

    group-exchange kex should work now on the server side.  it will only be
    advertised if a "moduli" file has been loaded (see the -gasp- docs) so we
    don't spend hours (literally. hours.) computing primes.  some of the logic
    was previously wrong, too, since it had never been tested.
    
    fixed repr() string for Transport/BaseTransport.  moved is_authenticated to
    Transport where it belongs.
    
    added lots of documentation (but still only about 10% documented).  lots of
    methods were made private finally.

    new files:
     paramiko/.arch-ids/primes.py.id paramiko/primes.py

    modified files:
     NOTES demo.py demo_server.py paramiko/__init__.py
     paramiko/auth_transport.py paramiko/channel.py
     paramiko/kex_gex.py paramiko/kex_group1.py
     paramiko/transport.py paramiko/util.py


2003-12-27 02:03:44 GMT	Robey Pointer <robey@lag.net>	patch-15

    Summary:
      fix up new paramiko/ folder.
    Revision:
      secsh--dev--1.0--patch-15

    moved SSHException to a new file (ssh_exception.py) and turned paramiko.py
    into an __init__.py file.  i'm still not entirely sure how this normally
    works, so i may have done something wrong, but it's supposed to work the
    same as before.

    new files:
     paramiko/.arch-ids/__init__.py.id
     paramiko/.arch-ids/ssh_exception.py.id paramiko/__init__.py
     paramiko/ssh_exception.py

    modified files:
     paramiko/auth_transport.py paramiko/channel.py
     paramiko/dsskey.py paramiko/kex_gex.py paramiko/kex_group1.py
     paramiko/transport.py


2003-12-27 01:49:19 GMT	Robey Pointer <robey@lag.net>	patch-14

    Summary:
      move the paramiko files into a paramiko/ folder.
    Revision:
      secsh--dev--1.0--patch-14

    just moving the files into a folder.  it won't build this way yet.

    new files:
     paramiko/.arch-ids/=id

    renamed files:
     .arch-ids/auth_transport.py.id
       ==> paramiko/.arch-ids/auth_transport.py.id
     .arch-ids/ber.py.id
       ==> paramiko/.arch-ids/ber.py.id
     .arch-ids/channel.py.id
       ==> paramiko/.arch-ids/channel.py.id
     .arch-ids/dsskey.py.id
       ==> paramiko/.arch-ids/dsskey.py.id
     .arch-ids/kex_gex.py.id
       ==> paramiko/.arch-ids/kex_gex.py.id
     .arch-ids/kex_group1.py.id
       ==> paramiko/.arch-ids/kex_group1.py.id
     .arch-ids/message.py.id
       ==> paramiko/.arch-ids/message.py.id
     .arch-ids/rsakey.py.id
       ==> paramiko/.arch-ids/rsakey.py.id
     .arch-ids/transport.py.id
       ==> paramiko/.arch-ids/transport.py.id
     .arch-ids/util.py.id
       ==> paramiko/.arch-ids/util.py.id
     auth_transport.py
       ==> paramiko/auth_transport.py
     ber.py
       ==> paramiko/ber.py
     channel.py
       ==> paramiko/channel.py
     dsskey.py
       ==> paramiko/dsskey.py
     kex_gex.py
       ==> paramiko/kex_gex.py
     kex_group1.py
       ==> paramiko/kex_group1.py
     message.py
       ==> paramiko/message.py
     rsakey.py
       ==> paramiko/rsakey.py
     transport.py
       ==> paramiko/transport.py
     util.py
       ==> paramiko/util.py

    new directories:
     paramiko paramiko/.arch-ids


2003-12-24 22:09:43 GMT	Robey Pointer <robey@lag.net>	patch-13

    Summary:
      fix a deadlock/race in handle_eof & close
    Revision:
      secsh--dev--1.0--patch-13

    (patch from fred gansevles)
    add locking around the eof handler and the close() call, so we can't be in
    both simultaneously.

    modified files:
     channel.py


2003-12-24 20:49:38 GMT	Robey Pointer <robey@lag.net>	patch-12

    Summary:
      fix dss key signing
    Revision:
      secsh--dev--1.0--patch-12

    (expanded on a patch from fred gansevles)
    add a demo dss key for server mode, and fix some bugs that had caused the dss
    signing stuff to never work before.  the demo_server is a bit more verbose
    now, too.  both key types (RSAKey & DSSKey) now have a function to return the
    fingerprint of the key, and both versions of read_private_key_file() now raise
    exceptions on failure, instead of just silently setting "valid" to false.

    new files:
     .arch-ids/demo_dss_key.id demo_dss_key

    modified files:
     demo_server.py dsskey.py kex_gex.py kex_group1.py paramiko.py
     rsakey.py transport.py


2003-12-23 06:44:56 GMT	Robey Pointer <robey@lag.net>	patch-11

    Summary:
      in server mode, don't offer keys we don't have
    Revision:
      secsh--dev--1.0--patch-11

    (from Paolo Losi) in server mode, when advertising which key methods we
    support, don't list methods that we don't have any existing keys for.

    modified files:
     transport.py


2003-12-23 06:36:27 GMT	Robey Pointer <robey@lag.net>	patch-10

    Summary:
      add logfiles and .pyc files to the "junk" list
    Revision:
      secsh--dev--1.0--patch-10

    add *.log and *.pyc to the explicit junk list.

    modified files:
     {arch}/=tagging-method


2003-11-10 08:49:50 GMT	Robey Pointer <robey@lag.net>	patch-9

    Summary:
      rename secsh -> paramiko
    Revision:
      secsh--dev--1.0--patch-9

    also, rename SecshException back to SSHException.  sigh. :)

    modified files:
     ./MANIFEST ./Makefile ./NOTES ./README ./auth_transport.py
     ./channel.py ./demo.py ./demo_server.py ./kex_gex.py
     ./kex_group1.py ./message.py ./paramiko.py ./setup.py
     ./transport.py

    renamed files:
     ./.arch-ids/secsh.py.id
       ==> ./.arch-ids/paramiko.py.id
     ./secsh.py
       ==> ./paramiko.py


2003-11-10 06:52:35 GMT	Robey Pointer <robey@lag.net>	patch-8

    Summary:
      doc changes
    Revision:
      secsh--dev--1.0--patch-8


    modified files:
     ./README ./demo_server.py ./secsh.py


2003-11-10 04:54:02 GMT	Robey Pointer <robey@lag.net>	patch-7

    Summary:
      cleaned up server code, renamed some files & classes
    Revision:
      secsh--dev--1.0--patch-7

    renamed demo-server.py and demo-host-key to demo_server.py and
    demo_host_key, just to be consistent.
    
    renamed SSHException -> SecshException.
    
    generalized the mechanism where Channel decides whether to allow
    different channel requests: 4 of the main ones (pty, window-change,
    shell, and subsystem) go through easily override-able methods now.
    you could probably make an actual ssh shell server.
    
    gave ChannelFile a repr().
    
    turned off ultra debugging in the demos.  demo_server creates a
    subclass of Channel to allow pty/shell and sets an event when the
    shell request is made, so that it knows when it can start sending
    the fake bbs.
    
    renamed to charmander and updated some of the distutils files.

    modified files:
     ./MANIFEST ./NOTES ./auth_transport.py ./channel.py ./demo.py
     ./demo_server.py ./kex_gex.py ./kex_group1.py ./secsh.py
     ./setup.py ./transport.py

    renamed files:
     ./.arch-ids/demo-host-key.id
       ==> ./.arch-ids/demo_host_key.id
     ./.arch-ids/demo-server.py.id
       ==> ./.arch-ids/demo_server.py.id
     ./demo-host-key
       ==> ./demo_host_key
     ./demo-server.py
       ==> ./demo_server.py


2003-11-09 21:16:35 GMT	Robey Pointer <robey@lag.net>	patch-6

    Summary:
      notes about the exported api
    Revision:
      secsh--dev--1.0--patch-6

    just wrote some quick notes (for a few of the classes) about which
    methods are intended to be the exported API.  python has no decent
    way of distinguishing private vs public.
    

    modified files:
     ./NOTES


2003-11-09 21:14:21 GMT	Robey Pointer <robey@lag.net>	patch-5

    Summary:
      big chunk of work which makes server code 95% done
    Revision:
      secsh--dev--1.0--patch-5

    fixed auth check methods to return just a result (failed, succeeded,
    partially succeeded) and always use get_allowed_auths to determine the
    list of allowed auth methods to return.
    
    channel's internal API changed a bit to allow for client-side vs.
    server-side channels.  we now honor the "want-reply" bit from channel
    requests.  in server mode (for now), we automatically allow pty-req
    and shell requests without doing anything.
    
    ChannelFile was fixed up a bit to support universal newlines.  readline
    got rewritten: the old way used the "greedy" read call from ChannelFile,
    which won't work if the socket doesn't have that much data buffered and
    ready.  now it uses recv directly, and tracks the different newlines.
    
    demo-server.py now answers to a single shell request (like a CLI ssh
    tool will make) and does a very simple demo pretending to be a BBS.
    
    transport: fixed a bug with parsing the remote side's banner.  channel
    requests are passed to another method in server mode, to determine if
    we should allow it.  new allowed channels are added to an accept queue,
    and a new method 'accept' (with timeout) will block until the next
    incoming channel is ready.
    

    modified files:
     ./auth_transport.py ./channel.py ./demo-server.py ./demo.py
     ./transport.py


2003-11-09 20:59:51 GMT	Robey Pointer <robey@lag.net>	patch-4

    Summary:
      change kex-gex server code to generate primes by hand
    Revision:
      secsh--dev--1.0--patch-4

    added a util function "generate_prime" to compare to the incredibly slow C
    version, but it's no faster of course.  i think kex-gex from the server is
    just not going to be feasible without having a separate thread generate some
    primes in the background to have handy when a request comes in.  so in short,
    this still doesn't work.
    
    also i put bit_length into util and a tb_strings function which gets stack
    traceback info and splits it into a list of strings.
    

    modified files:
     ./kex_gex.py ./util.py


2003-11-07 10:36:42 GMT	Robey Pointer <robey@lag.net>	patch-3

    Summary:
      remove some leftover garbage from dsskey
    Revision:
      secsh--dev--1.0--patch-3

    leftover from a cut & paste i was doing a few days ago.  bad robey.

    modified files:
     ./dsskey.py


2003-11-06 07:34:27 GMT	Robey Pointer <robey@lag.net>	patch-2

    Summary:
      add a demo host key and point demo-server at it.
    Revision:
      secsh--dev--1.0--patch-2

    also, temporarily comment out the nonfunctional kex-gex method.

    new files:
     ./.arch-ids/demo-host-key.id ./demo-host-key

    modified files:
     ./demo-server.py ./transport.py


2003-11-04 08:50:22 GMT	Robey Pointer <robey@lag.net>	patch-1

    Summary:
      no changes
    Revision:
      secsh--dev--1.0--patch-1

    why aren't my log messages kept?

    modified files:
     ./kex_gex.py

    new patches:
     robey@lag.net--2003/secsh--dev--1.0--patch-1


2003-11-04 08:34:24 GMT	Robey Pointer <robey@lag.net>	base-0

    Summary:
      initial import
    Revision:
      secsh--dev--1.0--base-0

    
    (automatically generated log message)

    new files:
     ./LICENSE ./MANIFEST ./Makefile ./NOTES ./README
     ./auth_transport.py ./ber.py ./channel.py ./demo-server.py
     ./demo.py ./dsskey.py ./kex_gex.py ./kex_group1.py
     ./message.py ./rsakey.py ./secsh.py ./setup.py ./transport.py
     ./util.py

    new patches:
     robey@lag.net--2003/secsh--dev--1.0--base-0