Changes between Version 4 and Version 5 of GROUP_APP_SERVER_RESOURCE_ACCESS_R0


Ignore:
Timestamp:
06/09/09 13:42:59 (16 years ago)
Author:
boyan
Comment:

--

Legend:

Unmodified
Added
Removed
Modified
  • GROUP_APP_SERVER_RESOURCE_ACCESS_R0

    v4 v5  
    55= Analysis = 
    66 
    7  
    87== Overview == 
    9 We want to open a book with Sophie2, which resides on the Sophie2 Server. This action should be available through a dedicated palette for server resource listing. 
     8This group of tasks is about accessing resources on the server from the client application. Sophie2 Author and Reader should provide a palette that lists the resources on a given server and allows actions to be taken on them. The server, on the other hand, should provide a facade and web services for resource access. At this iteration, a prototype of this will be created, allowing users to remotely open a book that resides on the Sophie 2 Server. 
    109 
    1110== Task requirements == 
    12  * Code requirements: 
    13   * Create palette for listing server resources, make it work synchronously with the existing connections palette. 
    14   * Add interface for resource part of the facade, since it currently has only user and group interfaces. This facade functionality will need 2 imlpementations : server-side and client-side. The client side will be used by the palette, the server one will provide resource access to the web services and the web UI. 
    15   * Decompose the server in appropriate modules, at least having separate persistence and core. See the implementation idea for this. Refactoring will be needed. 
    16    * For this revision, it would be better to fake the persistence module - everything will be persisted in the memory. This way, implementation will be easier and module dependency will be minimal. 
    17    * The S2S core module must work with real Sophie2 resources, users and groups must be also resources (users and groups are part of another task, but they must be integrated in the new structure anyway). S2S core should not be directly accessible from the web ui, web services ot from the client. Only the facade will be able to do this. 
    18    * Facade will expose the core functionality to the WS, DC and Web UI. It will have direct access only to the core. 
    19   * S2S core should have the ability to work with custom Sophie2 resources, the facade should provide these methods to the other modules. The web services must be able to serialize the resources in order to pass them to the client. 
    20  * UI : 
     11 * Decompose the server in appropriate modules with well-defined functionality (and do the refactoring needed): 
     12  * The core and the persistence should remain in separate modules. 
     13  * Persistence at this iteration is not a requirement. It can be fake (dumping everything to memory) for ease of implementation. 
     14  * S2S Core module should use the base resource model of Sophie2 (that includes book, users and groups at this iteration). 
     15  * S2S Core should be accessible from the web UI, the web services or the client only through the facade. 
     16  * Facade will expose the core functionality to the WS, DC and Web UI. It will have direct access only to the core. 
     17  * See the Implementation idea for a draft diagram of the modules decomposition. 
     18 * Add resource access support to the facade (it currently only provides access to user and group managers): 
     19  * Implement both the server-side and the client-side of the facade. The former will provide resource access to the web services and the web UI, while the latter will be used by the new palette created. 
     20 * Provide ability for the web services to serialize resources in order to pass them to the client. 
     21 * Create a palette for listing server resources and make it work synchronously with the existing Connections palette (i.e. display the resources of the server we are connected to): 
     22  * It should be in the Servers tab in the left flap. 
     23  * At this iteration it should list all the resources on the server (users, groups, books). No resource list filtering is required. 
     24  * It should support opening a book on a double-click (other actions will be implemented at a next iteration). 
     25  * It should be consistent with the Resources palette. 
    2126 
    2227== Task result == 
    23 Ability to open a book from the server. 
     28 * Source code: 
     29  * New Server module structure. 
     30  * Ability to open a book from the server. 
    2431 
    2532== Implementation idea == 
    26  (It would be good to put a diagram for the new module decomposition here.)  
     33Here's a draft diagram, showing the new module decomposition. 
     34 
     35^Put a diagram for the new module decomposition here. 
    2736 
    2837== Related == 
     
    3140 
    3241== How to demo == 
    33 Start Sophie2. Click on the "connect" button in the left flap/servers tab/connections palette. Double click on a book from the list below, it should open. Quit Sophie2, show the new server module structure, run the tests. 
     42 * Start Sophie2 Server and Author. 
     43 * Connect to a server from the Left Flap -> Servers Tab -> Connections palette. 
     44 * Double-click on a book from the list below. 
     45 * Show the new module structure. 
     46 * Run the test and briefly describe the changes made. 
    3447 
    3548= Design = 
    36 ^(Describe your design here.)^ 
     49^Describe your design here. 
    3750 
    3851= Implementation = 
    39 ^(Describe and link the implementation results here (from the wiki or the repository).)^ 
     52^Describe and link the implementation results here (from the wiki or the repository). 
    4053 
    4154= Testing = 
    42 ^(Place the testing results here.)^ 
     55^Place the testing results here. 
    4356 
    4457= Comments = 
    45 ^(Write comments for this or later revisions here.) 
     58 * Implement the resource list filtering at the next iteration of this task or of [wiki:APP_SERVER_RESOURCE_BROWSER_FILTER_R0] ([ticket:512]) --boyan@2009-06-09