mirror of
https://github.com/ziglang/zig.git
synced 2025-12-09 15:53:08 +00:00
std.crypto.tls: rework for new std.Io API
This commit is contained in:
parent
02908a2d8c
commit
28190cc404
@ -1306,31 +1306,6 @@ pub fn defaultRebase(r: *Reader, capacity: usize) RebaseError!void {
|
|||||||
r.end = data.len;
|
r.end = data.len;
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Advances the stream and decreases the size of the storage buffer by `n`,
|
|
||||||
/// returning the range of bytes no longer accessible by `r`.
|
|
||||||
///
|
|
||||||
/// This action can be undone by `restitute`.
|
|
||||||
///
|
|
||||||
/// Asserts there are at least `n` buffered bytes already.
|
|
||||||
///
|
|
||||||
/// Asserts that `r.seek` is zero, i.e. the buffer is in a rebased state.
|
|
||||||
pub fn steal(r: *Reader, n: usize) []u8 {
|
|
||||||
assert(r.seek == 0);
|
|
||||||
assert(n <= r.end);
|
|
||||||
const stolen = r.buffer[0..n];
|
|
||||||
r.buffer = r.buffer[n..];
|
|
||||||
r.end -= n;
|
|
||||||
return stolen;
|
|
||||||
}
|
|
||||||
|
|
||||||
/// Expands the storage buffer, undoing the effects of `steal`
|
|
||||||
/// Assumes that `n` does not exceed the total number of stolen bytes.
|
|
||||||
pub fn restitute(r: *Reader, n: usize) void {
|
|
||||||
r.buffer = (r.buffer.ptr - n)[0 .. r.buffer.len + n];
|
|
||||||
r.end += n;
|
|
||||||
r.seek += n;
|
|
||||||
}
|
|
||||||
|
|
||||||
test fixed {
|
test fixed {
|
||||||
var r: Reader = .fixed("a\x02");
|
var r: Reader = .fixed("a\x02");
|
||||||
try testing.expect((try r.takeByte()) == 'a');
|
try testing.expect((try r.takeByte()) == 'a');
|
||||||
|
|||||||
@ -49,8 +49,8 @@ pub const hello_retry_request_sequence = [32]u8{
|
|||||||
};
|
};
|
||||||
|
|
||||||
pub const close_notify_alert = [_]u8{
|
pub const close_notify_alert = [_]u8{
|
||||||
@intFromEnum(AlertLevel.warning),
|
@intFromEnum(Alert.Level.warning),
|
||||||
@intFromEnum(AlertDescription.close_notify),
|
@intFromEnum(Alert.Description.close_notify),
|
||||||
};
|
};
|
||||||
|
|
||||||
pub const ProtocolVersion = enum(u16) {
|
pub const ProtocolVersion = enum(u16) {
|
||||||
@ -138,13 +138,17 @@ pub const ExtensionType = enum(u16) {
|
|||||||
_,
|
_,
|
||||||
};
|
};
|
||||||
|
|
||||||
pub const AlertLevel = enum(u8) {
|
pub const Alert = struct {
|
||||||
|
level: Level,
|
||||||
|
description: Description,
|
||||||
|
|
||||||
|
pub const Level = enum(u8) {
|
||||||
warning = 1,
|
warning = 1,
|
||||||
fatal = 2,
|
fatal = 2,
|
||||||
_,
|
_,
|
||||||
};
|
};
|
||||||
|
|
||||||
pub const AlertDescription = enum(u8) {
|
pub const Description = enum(u8) {
|
||||||
pub const Error = error{
|
pub const Error = error{
|
||||||
TlsAlertUnexpectedMessage,
|
TlsAlertUnexpectedMessage,
|
||||||
TlsAlertBadRecordMac,
|
TlsAlertBadRecordMac,
|
||||||
@ -203,8 +207,8 @@ pub const AlertDescription = enum(u8) {
|
|||||||
no_application_protocol = 120,
|
no_application_protocol = 120,
|
||||||
_,
|
_,
|
||||||
|
|
||||||
pub fn toError(alert: AlertDescription) Error!void {
|
pub fn toError(description: Description) Error!void {
|
||||||
switch (alert) {
|
switch (description) {
|
||||||
.close_notify => {}, // not an error
|
.close_notify => {}, // not an error
|
||||||
.unexpected_message => return error.TlsAlertUnexpectedMessage,
|
.unexpected_message => return error.TlsAlertUnexpectedMessage,
|
||||||
.bad_record_mac => return error.TlsAlertBadRecordMac,
|
.bad_record_mac => return error.TlsAlertBadRecordMac,
|
||||||
@ -235,6 +239,7 @@ pub const AlertDescription = enum(u8) {
|
|||||||
_ => return error.TlsAlertUnknown,
|
_ => return error.TlsAlertUnknown,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
pub const SignatureScheme = enum(u16) {
|
pub const SignatureScheme = enum(u16) {
|
||||||
@ -650,7 +655,7 @@ pub const Decoder = struct {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/// Use this function to increase `their_end`.
|
/// Use this function to increase `their_end`.
|
||||||
pub fn readAtLeast(d: *Decoder, stream: anytype, their_amt: usize) !void {
|
pub fn readAtLeast(d: *Decoder, stream: *std.io.Reader, their_amt: usize) !void {
|
||||||
assert(!d.disable_reads);
|
assert(!d.disable_reads);
|
||||||
const existing_amt = d.cap - d.idx;
|
const existing_amt = d.cap - d.idx;
|
||||||
d.their_end = d.idx + their_amt;
|
d.their_end = d.idx + their_amt;
|
||||||
@ -658,14 +663,16 @@ pub const Decoder = struct {
|
|||||||
const request_amt = their_amt - existing_amt;
|
const request_amt = their_amt - existing_amt;
|
||||||
const dest = d.buf[d.cap..];
|
const dest = d.buf[d.cap..];
|
||||||
if (request_amt > dest.len) return error.TlsRecordOverflow;
|
if (request_amt > dest.len) return error.TlsRecordOverflow;
|
||||||
const actual_amt = try stream.readAtLeast(dest, request_amt);
|
stream.readSlice(dest[0..request_amt]) catch |err| switch (err) {
|
||||||
if (actual_amt < request_amt) return error.TlsConnectionTruncated;
|
error.EndOfStream => return error.TlsConnectionTruncated,
|
||||||
d.cap += actual_amt;
|
error.ReadFailed => return error.ReadFailed,
|
||||||
|
};
|
||||||
|
d.cap += request_amt;
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Same as `readAtLeast` but also increases `our_end` by exactly `our_amt`.
|
/// Same as `readAtLeast` but also increases `our_end` by exactly `our_amt`.
|
||||||
/// Use when `our_amt` is calculated by us, not by them.
|
/// Use when `our_amt` is calculated by us, not by them.
|
||||||
pub fn readAtLeastOurAmt(d: *Decoder, stream: anytype, our_amt: usize) !void {
|
pub fn readAtLeastOurAmt(d: *Decoder, stream: *std.io.Reader, our_amt: usize) !void {
|
||||||
assert(!d.disable_reads);
|
assert(!d.disable_reads);
|
||||||
try readAtLeast(d, stream, our_amt);
|
try readAtLeast(d, stream, our_amt);
|
||||||
d.our_end = d.idx + our_amt;
|
d.our_end = d.idx + our_amt;
|
||||||
|
|||||||
File diff suppressed because it is too large
Load Diff
@ -343,10 +343,9 @@ pub const Reader = struct {
|
|||||||
/// read from `in`.
|
/// read from `in`.
|
||||||
trailers: []const u8 = &.{},
|
trailers: []const u8 = &.{},
|
||||||
body_err: ?BodyError = null,
|
body_err: ?BodyError = null,
|
||||||
/// Stolen from `in`.
|
/// Determines at which point `error.HttpHeadersOversize` occurs, as well
|
||||||
head_buffer: []u8 = &.{},
|
/// as the minimum buffer capacity of `in`.
|
||||||
|
max_head_len: usize,
|
||||||
pub const max_chunk_header_len = 22;
|
|
||||||
|
|
||||||
pub const RemainingChunkLen = enum(u64) {
|
pub const RemainingChunkLen = enum(u64) {
|
||||||
head = 0,
|
head = 0,
|
||||||
@ -398,19 +397,11 @@ pub const Reader = struct {
|
|||||||
ReadFailed,
|
ReadFailed,
|
||||||
};
|
};
|
||||||
|
|
||||||
pub fn restituteHeadBuffer(reader: *Reader) void {
|
/// Buffers the entire head.
|
||||||
reader.in.restitute(reader.head_buffer.len);
|
|
||||||
reader.head_buffer.len = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
/// Buffers the entire head into `head_buffer`, invalidating the previous
|
|
||||||
/// `head_buffer`, if any.
|
|
||||||
pub fn receiveHead(reader: *Reader) HeadError!void {
|
pub fn receiveHead(reader: *Reader) HeadError!void {
|
||||||
reader.trailers = &.{};
|
reader.trailers = &.{};
|
||||||
const in = reader.in;
|
const in = reader.in;
|
||||||
in.restitute(reader.head_buffer.len);
|
try in.rebase(reader.max_head_len);
|
||||||
reader.head_buffer.len = 0;
|
|
||||||
in.rebase();
|
|
||||||
var hp: HeadParser = .{};
|
var hp: HeadParser = .{};
|
||||||
var head_end: usize = 0;
|
var head_end: usize = 0;
|
||||||
while (true) {
|
while (true) {
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user