Project

General

Profile

Story #18846

Updated by Peter Amstutz almost 3 years ago

h2. Goal 

 Be able to include rich rendering of user-defined object properties or link/embed externally-derived content on Where is the Project and Collection pages. data stored? 

 h2. Proposal 

 In Workbench 2, add a "description" panel to the collection and * Arvados project pages properties 
 ** Searchable 
 ** report generator must have write access 
 * Arvados link objects 
 ** Can describe things that renders the "description" user account doesn't have write access to 
 * Description field of the object. 

 Also add a "banner" configuration value 
 ** Report generator adds link to badge in config file, this is description 
 ** Not searchable (unless it also displayed either as part of the description panel or fills in its own panel, but metadata) 
 ** report generator must have write access 
 * External service 

 h2. How is rendered for every project or collection object on the cluster. data rendered? 

 Introduce a simple template language (suggested: "Go templates":https://pkg.go.dev/text/template ) 

 The "description" field contains HTML * Plugin (written in javascript / typescript) 
 ** Read properties or link metadata, render arbitrary presentation 
 ** cons: More complex implementation, need to build custom workbench with an additional template language.    For display, the template is rendered then the plugin enabled 
 * Badge 
 ** fetch image by URL and render it as clickable link 
 ** cons: Rendering issues 
 * Fetch HTML is sanitized to remove scripts by URL and limited to a whitelist of tags.    Then inject it into the HTML page 
 ** Can render anything 
 ** Requires external service 
 ** cons: Rendering issues 
 ** cons: Security issues 

 h2. How is embedded it configured? 

 * Plugin 
 ** Requires compiling custom workbench package 
 * Config file 
 ** Would be part of public global config 
 * Filling in the panel. description field 
 ** no global configuration required 

 Templates have idea: lightweight parameter substitution system for description field, which gives access to the fields of the current object (e.g. uuid, user-defined properties, etc).    Templates should be able to create links or image URLs to things hosted by keep-web.    Templates should also automatically turn UUIDs and PDHs into links. record. 

 Support server-side rendering (maybe an additional "render_description=true" parameter on GET request).    Include read-only "description_html" field. 

 h2. Use case: User wants need to assign a "FAIR data" score to projects. 

 External service exists that takes an Arvados UUID and produces a report. 

 Implementation: make the "banner" has a template which checks if the current object is a project, if so, it embeds an image badge that links to the external scoring service by using the template to construct a URL containing the project UUID.    The service returns a badge with the score (1-5). Clicking description field on the badge goes to the report. 

 So when a user goes to a project page, it renders banner that displays the badge with the project score. projects more visible 

Back