DocumentCode :
1519663
Title :
Zebu: A Language-Based Approach for Network Protocol Message Processing
Author :
Burgy, Laurent ; Réveillère, Laurent ; Lawall, Julia ; Muller, Gilles
Author_Institution :
Princeton Univ., Princeton, NJ, USA
Volume :
37
Issue :
4
fYear :
2011
Firstpage :
575
Lastpage :
591
Abstract :
A network application communicates with other applications according to a set of rules known as a protocol. This communication is managed by the part of the application known as the protocol-handling layer, which enables the manipulation of protocol messages. The protocol-handling layer is a critical component of a network application since it represents the interface between the application and the outside world. It must thus satisfy two constraints: It must be efficient to be able to treat a large number of messages and it must be robust to face various attacks targeting the application itself or the underlying platform. Despite these constraints, the development process of this layer still remains rudimentary and requires a high level of expertise. It includes translating the protocol specification written in a high-level formalism such as ABNF toward low-level code such as C. The gap between these abstraction levels can entail many errors. This paper proposes a new language-based approach to developing protocol-handling layers, to improve their robustness without compromising their performance. Our approach is based on the use of a domain-specific language, Zebu, to specify the protocol-handling layer of network applications that use textual HTTP-like application protocols. The Zebu syntax is very close to that of ABNF, facilitating the adoption of Zebu by domain experts. By annotating the original ABNF specification of a protocol, the Zebu user can dedicate the protocol-handling layer to the needs of a given application. The Zebu compiler first checks the annotated specification for inconsistencies, and then generates a protocol-handling layer according to the annotations. This protocol-handling layer is made up of a set of data structures that represent a message, a parser that fills in these data structures, and various stub functions to access these data structures or drive the parsing of a message.
Keywords :
Internet; computational linguistics; formal specification; program compilers; protocols; specification languages; telecommunication computing; ABNF; Internet era; Zebu compiler; Zebu syntax; data structures; domain-specific languages; language-based approach; message parsing; network protocol message processing; protocol specification; protocol-handling layer; textual HTTP-like application protocols; Access protocols; Computer bugs; Data structures; Domain specific languages; Electronic mail; IP networks; Network servers; Robustness; Streaming media; Web server; Network protocols; domain-specific languages.; message composing; message parsing;
fLanguage :
English
Journal_Title :
Software Engineering, IEEE Transactions on
Publisher :
ieee
ISSN :
0098-5589
Type :
jour
DOI :
10.1109/TSE.2010.64
Filename :
5487528
Link To Document :
بازگشت