The stream-based service-centred calculus: A foundation for service-oriented programming

  • L. Cruz-Filipe
  • , Ivan Lanese
  • , Francisco Martins
  • , António Ravara
  • , Vasco Vasconcelos

Research output: Journal Article or Conference Article in JournalJournal articleResearchpeer-review

Abstract

We give a formal account of SSCC, a calculus for modeling service-based systems, suitable to describe both service composition (orchestration) and the protocols that services follow when invoked (conversation). The calculus includes primitives for defining and invoking services, for isolating conversations (called sessions) among clients and servers, and for orchestrating services. The calculus is equipped with a reduction and a labeled transition semantics related by an equivalence result. SSCC provides a good trade-off between expressive power for modeling and simplicity for analysis. We assess the expressive power by modeling van der Aalst workflow patterns and an automotive case study from the European project Sensoria. For analysis, we present a simple type system ensuring compatibility of client and service protocols. We also study the behavioral theory of the calculus, highlighting some axioms that capture the behavior of the different primitives. As a final application of the theory, we define and prove correct some program transformations. These allow to start modeling a system from a typical UML Sequence Diagram, and then transform the specification to match the service-oriented programming style, thus simplifying its implementation using web services technology.
Original languageEnglish
JournalFormal Aspects of Computing
Volume26
Issue number5
Pages (from-to)865-918
Number of pages54
ISSN0934-5043
DOIs
Publication statusPublished - 1 Sept 2014
Externally publishedYes

Fingerprint

Dive into the research topics of 'The stream-based service-centred calculus: A foundation for service-oriented programming'. Together they form a unique fingerprint.

Cite this