500 likes | 653 Views
Service Context Management for Exertion-oriented Programming. Greg McChesney Thesis Defense Presentation Computer Science, TTU greg.mcchesney@ttu.edu. Presentation Agenda . Problem Statement Objective Background knowledge Design Verification and Validation Implementation Demonstration
E N D
Service Context Management for Exertion-oriented Programming Greg McChesney Thesis Defense Presentation Computer Science, TTU greg.mcchesney@ttu.edu
Presentation Agenda • Problem Statement • Objective • Background knowledge • Design • Verification and Validation • Implementation • Demonstration • Benefits Greg McChesney Beginning
Problem Statement • Problem • No full life-cycle for context management in exertion-oriented programming • The current Cataloger service does not sufficiently display context details • No service UI context editor for interactive exertion-oriented programming • No standard service UI for all providers Greg McChesney Beginning
Problem Statement • Conclusion • A life-cycle context management is needed. • Life-cycle must support: • Creating Contexts • Updating Contexts • Deleting Contexts Greg McChesney Beginning
Thesis Objectives • Create a life-cycle to manage contexts • Provide service UI to allow for interactive exertion-oriented programming • Ease new provider development in SORCER • Provider a common framework for Context modifications • Minimize the modifications required to existing providers Greg McChesney Beginning
Overview of Contexts • A service context is a basic data structure in SOOA • Used for communication between provider and requestor (a data exchange contract) • A service context depends on the provider and the method being executed • Data specification of hierarchical attributes the method will require • Stored in a tree like format of path/value Greg McChesney
Sample Context Image courtesy of Dr. Sobolewski Greg McChesney
Need for a Life-Cycle • Two roles • Provider-provides a service to the network • The service can be requested via an exertion • Provider expects a context from the requestor with arguments for the method. • Requestor- is the client who connects to the provider • Requestor creates exertion which is sent to provider • Requestor must send context in a structure provider will understand Greg McChesney
Need for a Life-Cycle • Provider’s Issues • No methodology to obtain a service context from a provider • No methodology to interactively create network centric contexts • No method of updating or removing a context from a provider Greg McChesney
Need for a Life-Cycle • Requestor’s Issues • Exertion-oriented programming cannot be network centric without context management • Two new service UIs - Context Browser in Cataloger Service UI and in Exertion Editor will provide more accessibility • Need service context editing operations for EO programming Greg McChesney
Proposed Life-Cycle • Implement service context editing operations into provider classes • New operations will be remotely invokeable • Get- Requestor • Save -Admin • Delete -Admin • Create Context Browser to utilize the methods • Create Exertion Editor which will allow for service context and exertion creation Greg McChesney
Life-Cycle Explained • Context’s must be: • Stored locally by provider • Reloaded on provider restart • Saved on update/create • Return undefined service context on error • Changes must be • Compliant with existing providers • Provide backup file in case of bad context Greg McChesney
Activity Diagram Greg McChesney
Different Components ProviderList InterfaceBrowser ContextEditor ControlPanel Greg McChesney
Use Case Diagram Context Browser Greg McChesney
Exertion Editor-Use Case Greg McChesney
Context Browser- Architecture Diagram Greg McChesney
Context Browser UI- Architecture Diagram Greg McChesney
Exertion Editor UI- Architecture Diagram Greg McChesney
Context Browser Sequence- Viewer Greg McChesney
Context Browser Sequence- Admin Greg McChesney
Exertion Editor-Sequence Creator Greg McChesney
Exertion Editor- Sequence Submitter Greg McChesney
Sargent Circle Requirements Check Requirements to Models Check Implementation to Requirements GroovyShell Data Validity Implementation UML Modeling Check Implementation to Models Greg McChesney
Implementation to Validate Model • Implementation is based on SORCER • Developed by Texas Tech SORCER Lab • SORCER is based on Jini network technology • Framework constantly evolving • Interoperability with existing providers a concern for new development Greg McChesney
Technical Architecture Context Browser Exertion Editor Utilities and Templates Web Exertion Based Clients Requestor Service UIs Intraportal Extraportal Infrastructure Providers Jobber, Tasker, Spacer, Grider, Caller,Methoder, Cataloger, Notifier, Logger, Reporter, Authenticator, Authorizer, Auditor, Policer, KeyStorer,Surrogater, Persister, FileStorer,SILENUS, FICUS SORCER Core Servicer, ServiceProvider, ServiceProviderBean ExertionDelegate, ServiceAccessor Persistence Provisioning and Activation File Store Exertion Layer J2EE, Jini, Rio, GApp Context Management Greg McChesney
Feasibility Study • Create the Context Browser provider to test Life-Cycle methods • Get Context • Add Context • Update Context • Delete Context • Utilize Arithmetic provider to demonstrate the power of the Exertion Editor. • Address new provider development with integrated user interfaces Greg McChesney
Deployment Greg McChesney
Demonstration Greg McChesney
Demonstration Context Browser Greg McChesney
Selecting a provider Select Provider Greg McChesney
Add New Provider New providers appear without disrupting the user Greg McChesney
Modifying a context Double click a data node to edit Greg McChesney
Supported Data Types • String • Integer • Boolean • Groovy Expression • Double • Float • URL Greg McChesney
Double click a path to edit Greg McChesney
Directions-control if the path is marked for a particular operation • Default • Input • Output • InOutput Greg McChesney
Functions Provided Removes currently selected item Adds a new path Adds a new data node Greg McChesney
Functions Provided Provides user a method to remove contexts Gives user option to load another saved context Empties the Context Greg McChesney
Functions Provided Exert the service and output result context Save this context as a different name Save this context Greg McChesney
Result of Exerting a Service Output context from exertion Greg McChesney
Groovy Expressions Enter expression in terms of arithmetic0’s value Greg McChesney
Result of Groovy Expression Output of the math operation Greg McChesney
Integrated Exertion Editor New provider echo has no user interface Greg McChesney
Utilize Default Editors Exertion Editor is now available for each provider Greg McChesney
Benefits • Uniform service context tracking by providers • Uniform method context viewer and editor for service providers • Intuitive Service UI for Cataloger service contexts per provider/interface method • Intuitive Service UI for task service context Greg McChesney
References • “Design Patterns: Model-View-Controller.” Java.sun.com. 01 Jan 2002. 20 Oct. 2008 <http://java.sun.com/blueprints/patterns/MVC.html> • Sobolewski, Michael. “SORCER Research.” SORCER Research Lab at TTU. 20 Oct. 2008. <http://sorcer.cs.ttu.edu/fiper/fiper.html> • Sargent, R. G. Verification, Validation, and Accreditation of Simulation Models. (J. A. Joines, R. R. Barton, K. Kang, & P. A. Fishwick, Eds.) • Sobolewski, Michael. “Exertion Oriented Programming.” Page 19. <http://sorcer.cs.ttu.edu/publications/papers/2008/SL-TR-13.pdf> • Soorianarayanan, Sekar and Sobolewski, Michael. SORCER Proth. Slide 6. <http://sorcer.cs.ttu.edu/publications/presentations/proth-hpcc.ppt> Greg McChesney