-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathprotocol.go
97 lines (85 loc) · 3.49 KB
/
protocol.go
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
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package api
import (
"context"
)
// The bunch of interfaces are structure skeleton to build a extensible protocol engine.
//
// In mosn, we have 4 layers to build a mesh, protocol is the core layer to do protocol related encode/decode.
// -----------------------
// | PROXY |
// -----------------------
// | STREAMING |
// -----------------------
// | PROTOCOL |
// -----------------------
// | NET/IO |
// -----------------------
//
// Stream layer leverages protocol's ability to do binary-model conversation. In detail, Stream uses Protocols's encode/decode facade method and DecodeFilter to receive decode event call.
//
type (
// MatchResult
MatchResult int
// ProtocolMatch recognize if the given data matches the protocol specification or not
ProtocolMatch func(data []byte) MatchResult
)
const (
MatchFailed MatchResult = iota
MatchSuccess
MatchAgain
)
// TODO: Protocol and api.Protocol have the same name, maybe makes some ambiguity.
// Protocol need to provides ability to convert mode-to-binary and vice-versa
type Protocol interface {
// Encoder is the encoder implementation of the protocol
Encoder
// Decoder is the decoder implementation of the protocol
Decoder
// Name is the name of the protocol
Name() ProtocolName
}
// ProtocolEngine is a protocols' facade used by Stream, it provides
// auto protocol detection by the ProtocolMatch func
type ProtocolEngine interface {
// Match use registered matchFunc to recognize corresponding protocol
Match(ctx context.Context, data IoBuffer) (Protocol, MatchResult)
// Register register encoder and decoder, which recognized by the matchFunc
Register(matchFunc ProtocolMatch, protocol Protocol) error
}
// Encoder is a encoder interface to extend various of protocols
type Encoder interface {
// Encode encodes a model to binary data
// return 1. encoded bytes 2. encode error
Encode(ctx context.Context, model interface{}) (IoBuffer, error)
// EncodeTo encodes a model to binary data, and append into the given buffer
// This method should be used in term of performance
// return 1. encoded bytes number 2. encode error
//EncodeTo(ctx context.Context, model interface{}, buf IoBuffer) (int, error)
}
// Decoder is a decoder interface to extend various of protocols
type Decoder interface {
// Decode decodes binary data to a model
// pass sub protocol type to identify protocol format
// return 1. decoded model(nil if no enough data) 2. decode error
Decode(ctx context.Context, data IoBuffer) (interface{}, error)
}
// HTTPMapping maps the contents of protocols to HTTP standard
type HTTPMapping interface {
MappingHeaderStatusCode(ctx context.Context, headers HeaderMap) (int, error)
}