Commit graph

  • 20b48c5432 move handshake handling and server config into handshake package Lucas Clemente 2016-04-15 22:24:42 +02:00
  • 30d5766598 improve version tests Lucas Clemente 2016-04-15 20:40:39 +02:00
  • 3e58bcfc69 change certificate to be valid for quic.clemente.io Lucas Clemente 2016-04-15 20:40:29 +02:00
  • 7acb3365d5 use dictionary to compress certificates Lucas Clemente 2016-04-15 20:39:48 +02:00
  • a6549d0cc7 add debug output when sending packets Lucas Clemente 2016-04-15 20:37:35 +02:00
  • 24d2878a06 Merge pull request #6 from lucas-clemente/frames Lucas Clemente 2016-04-15 20:35:10 +02:00
  • a2c4ebef19 add ConnctionClose frame handling Marten Seemann 2016-04-16 00:15:13 +07:00
  • 4e5102216a add tests for ACK frame parsing Marten Seemann 2016-04-15 18:09:43 +07:00
  • 23f0d8d6e9 read the STOP_WAITING frame Marten Seemann 2016-04-15 17:46:29 +07:00
  • 2b7847a178 pass complete frame (including the type byte) to the ParseFrame() functions Marten Seemann 2016-04-15 17:09:37 +07:00
  • 495bb0ef92 handle version Q030 properly Lucas Clemente 2016-04-15 19:01:14 +02:00
  • b6c9c9b6a4 introduce protocol/version.go and remove big endian functions Lucas Clemente 2016-04-15 18:46:39 +02:00
  • 052822aea5 send a body in the example server Lucas Clemente 2016-04-15 16:49:24 +02:00
  • 3c16e8c9ee introduce stream callback in session, move http2 stuff to main.go Lucas Clemente 2016-04-15 14:31:31 +02:00
  • ec509fb98f add key derivation test Lucas Clemente 2016-04-15 12:44:31 +02:00
  • 35a40ac6d8 rename GetCERTData to GetCertCompressed Lucas Clemente 2016-04-15 12:37:23 +02:00
  • bc88949ffb add a server config test Lucas Clemente 2016-04-15 12:34:01 +02:00
  • 2e1da961c5 add editorconfig Lucas Clemente 2016-04-15 12:13:33 +02:00
  • 85eceb53bf fix some linter issues Lucas Clemente 2016-04-15 12:06:43 +02:00
  • 53d6e62c85 add support for PAD frames Lucas Clemente 2016-04-15 12:05:42 +02:00
  • 50a1f802f9 add basic http2 header reading Lucas Clemente 2016-04-15 12:01:26 +02:00
  • be7d3004b3 Merge pull request #5 from lucas-clemente/frames marten-seemann 2016-04-15 16:52:04 +07:00
  • e223ed73e6 add very basic STOP_WAITING handling, return errors for unknown types Marten Seemann 2016-04-15 16:48:54 +07:00
  • a5a7021fed basic ACK frame parsing Marten Seemann 2016-04-15 16:00:15 +07:00
  • 281706fda8 better check for frame types Marten Seemann 2016-04-15 13:08:49 +07:00
  • 8da53885fc split STREAM and ACK frames in seperate files Marten Seemann 2016-04-15 12:34:23 +07:00
  • 9e87ee8ed9 detect different types of frames Marten Seemann 2016-04-15 12:29:02 +07:00
  • 86b4ffdaaf use chacha20poly1305 instead of AES and include cert in key derivation Lucas Clemente 2016-04-14 23:44:31 +02:00
  • 388fdf7399 decrease debug output Lucas Clemente 2016-04-14 20:40:20 +02:00
  • 1760bc3227 add key derivation and change AEAD in session, not working right now :( Lucas Clemente 2016-04-14 20:39:51 +02:00
  • 70531832af don't panic! 🎉 Lucas Clemente 2016-04-14 20:02:24 +02:00
  • 0febba87ba move crypto handshake stuff to its own package Lucas Clemente 2016-04-14 19:50:04 +02:00
  • 04921c29af introduce ConnectionID type Lucas Clemente 2016-04-14 19:39:49 +02:00
  • 09879ed4f7 move stuff from example server to new Session and SessionConfig classes Lucas Clemente 2016-04-14 17:56:19 +02:00
  • 49ccd0bb01 don't accept 0-byte connection IDs since we are a server Lucas Clemente 2016-04-14 16:37:12 +02:00
  • c0edd24a2e remove readNBytes func Marten Seemann 2016-04-14 17:55:28 +07:00
  • 3d767401d0 introduce PacketNumber type & protocol package Lucas Clemente 2016-04-14 10:29:21 +02:00
  • c6b3ce72eb Merge pull request #4 from lucas-clemente/aes-gcm Lucas Clemente 2016-04-14 10:10:05 +02:00
  • 8b7e2744da implement AES-GCM as AEAD Lucas Clemente 2016-04-14 09:56:39 +02:00
  • 3588f24ad4 Merge pull request #3 from marten-seemann/master marten-seemann 2016-04-14 14:55:50 +07:00
  • 55c6a51b45 send Version Negotiation Packet if the client uses the wrong QUIC version Marten Seemann 2016-04-14 14:29:25 +07:00
  • 703aad12c0 make WritePublicHeader set the VersionFlag and the ResetFlag Marten Seemann 2016-04-14 14:27:22 +07:00
  • 5b78f1613c add function to read and write uint32 big endians, use it for the QuicVersion Marten Seemann 2016-04-14 13:35:11 +07:00
  • 4f39e0f14d add tests for utils Marten Seemann 2016-04-14 11:30:22 +07:00
  • 98cd4aa513 Merge pull request #2 from marten-seemann/master Lucas Clemente 2016-04-13 11:41:06 +02:00
  • e8fc95466d fix QuicVersion32, enforce exact QuicVersion Marten Seemann 2016-04-13 14:39:59 +07:00
  • d5edeaf5c4 clean up example server debug output Lucas Clemente 2016-04-12 17:28:49 +02:00
  • 59ed21e690 add entropy accumulation Lucas Clemente 2016-04-12 17:03:24 +02:00
  • 284b86c02c send proper kex value in example server Lucas Clemente 2016-04-12 15:29:26 +02:00
  • 8b0d17828b add curve25519 key exchange Lucas Clemente 2016-04-12 15:20:16 +02:00
  • 83d8cb003d add test for RSA proof Lucas Clemente 2016-04-12 15:05:04 +02:00
  • aa786a1af1 read certificate path from $GOPATH in example server Lucas Clemente 2016-04-12 14:10:52 +02:00
  • 95e1b87302 add certificate handling to example server Lucas Clemente 2016-04-12 12:18:01 +02:00
  • 1e33917574 improve version check in example server Lucas Clemente 2016-04-12 12:17:29 +02:00
  • d3097ed82a implement basic certificate compression Lucas Clemente 2016-04-12 12:17:03 +02:00
  • 97187c5a31 fix proof signature algorithm Lucas Clemente 2016-04-12 12:16:46 +02:00
  • f634d2a577 add basic RSA server proof generation Lucas Clemente 2016-04-11 20:35:34 +02:00
  • daa77ec2a6 add writing of basic ack frames Lucas Clemente 2016-04-11 20:35:07 +02:00
  • df96797e9c fix an error reading n-byte integers Lucas Clemente 2016-04-11 14:41:21 +02:00
  • f293b525da add mock reply packet to example server Lucas Clemente 2016-04-10 20:33:46 +02:00
  • 96ae3efa64 simplify AEAD.Seal Lucas Clemente 2016-04-10 20:33:24 +02:00
  • 893704e38f implement sealing for NullAEAD Lucas Clemente 2016-04-10 20:23:51 +02:00
  • ab14684299 implement basic public header writing Lucas Clemente 2016-04-10 20:23:36 +02:00
  • 4a44e4982e move utils.go to its own package so that it's available for aeads Lucas Clemente 2016-04-10 20:23:15 +02:00
  • 07f5daa7ba remove lengths from public header struct Lucas Clemente 2016-04-10 20:02:35 +02:00
  • 551d5798e4 implement stream frame writer Lucas Clemente 2016-04-10 19:42:12 +02:00
  • 3dc0209b84 add godoc badge to readme Lucas Clemente 2016-04-10 18:43:32 +02:00
  • 9cb328ef8b implement sample server REJ message in example server Lucas Clemente 2016-04-10 18:40:09 +02:00
  • b2098f8f13 add some more crypto message tags Lucas Clemente 2016-04-10 16:34:05 +02:00
  • 120d255f38 implement writing of crypto messages Lucas Clemente 2016-04-10 16:33:55 +02:00
  • 0d4ebe0cfe update example program Lucas Clemente 2016-04-08 19:34:15 +02:00
  • 4df279dd81 implement parsing of sample CHLO crypto stream Lucas Clemente 2016-04-08 19:28:46 +02:00
  • 3492497230 improve util functions Lucas Clemente 2016-04-08 19:28:14 +02:00
  • 671557542b add example server Lucas Clemente 2016-04-08 12:56:15 +02:00
  • 981b061c0c implement parsing of stream frames Lucas Clemente 2016-04-08 12:17:47 +02:00
  • 1f30d50418 move readUint64 to new file utils.go Lucas Clemente 2016-04-08 12:10:21 +02:00
  • 7296d4e55e change AEAD interface to return bytes.Reader instead of io.Reader Lucas Clemente 2016-04-08 10:22:52 +02:00
  • 27c422a92b add travis.yml Lucas Clemente 2016-04-07 17:10:20 +02:00
  • 7d96666dd9 add travis button to readme Lucas Clemente 2016-04-07 17:08:19 +02:00
  • 990660ae3e add NullAEAD implementation Lucas Clemente 2016-04-07 17:02:26 +02:00
  • fc853a6e22 add AEAD interface Lucas Clemente 2016-04-07 17:02:07 +02:00
  • dae7b3dc75 improve FNV implementation Lucas Clemente 2016-04-07 17:02:00 +02:00
  • c495d80faa add a very simplistic and slow FNV-128a implementation Lucas Clemente 2016-04-07 13:22:36 +02:00
  • a29db728a3 improve public header tests Lucas Clemente 2016-04-07 11:19:50 +02:00
  • cfccdaed9b add public header parser Lucas Clemente 2016-04-06 23:10:52 +02:00
  • afdd7c3898 initial commit Lucas Clemente 2016-04-06 22:15:41 +02:00