<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="en">
	<id>https://wiki.cebitec.uni-bielefeld.de/brf-software/index.php?action=history&amp;feed=atom&amp;title=GPMSWiki%2FDeveloperDocumentation%2FDesignDocumentation</id>
	<title>GPMSWiki/DeveloperDocumentation/DesignDocumentation - Revision history</title>
	<link rel="self" type="application/atom+xml" href="https://wiki.cebitec.uni-bielefeld.de/brf-software/index.php?action=history&amp;feed=atom&amp;title=GPMSWiki%2FDeveloperDocumentation%2FDesignDocumentation"/>
	<link rel="alternate" type="text/html" href="https://wiki.cebitec.uni-bielefeld.de/brf-software/index.php?title=GPMSWiki/DeveloperDocumentation/DesignDocumentation&amp;action=history"/>
	<updated>2026-05-01T16:36:09Z</updated>
	<subtitle>Revision history for this page on the wiki</subtitle>
	<generator>MediaWiki 1.39.7</generator>
	<entry>
		<id>https://wiki.cebitec.uni-bielefeld.de/brf-software/index.php?title=GPMSWiki/DeveloperDocumentation/DesignDocumentation&amp;diff=2030&amp;oldid=prev</id>
		<title>Admin: 2 revisions</title>
		<link rel="alternate" type="text/html" href="https://wiki.cebitec.uni-bielefeld.de/brf-software/index.php?title=GPMSWiki/DeveloperDocumentation/DesignDocumentation&amp;diff=2030&amp;oldid=prev"/>
		<updated>2011-10-26T06:16:41Z</updated>

		<summary type="html">&lt;p&gt;2 revisions&lt;/p&gt;
&lt;table style=&quot;background-color: #fff; color: #202122;&quot; data-mw=&quot;interface&quot;&gt;
				&lt;tr class=&quot;diff-title&quot; lang=&quot;en&quot;&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: #fff; color: #202122; text-align: center;&quot;&gt;← Older revision&lt;/td&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: #fff; color: #202122; text-align: center;&quot;&gt;Revision as of 08:16, 26 October 2011&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-notice&quot; lang=&quot;en&quot;&gt;&lt;div class=&quot;mw-diff-empty&quot;&gt;(No difference)&lt;/div&gt;
&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;</summary>
		<author><name>Admin</name></author>
	</entry>
	<entry>
		<id>https://wiki.cebitec.uni-bielefeld.de/brf-software/index.php?title=GPMSWiki/DeveloperDocumentation/DesignDocumentation&amp;diff=2029&amp;oldid=prev</id>
		<title>imported&gt;JomunaChoudhuri at 15:28, 24 August 2005</title>
		<link rel="alternate" type="text/html" href="https://wiki.cebitec.uni-bielefeld.de/brf-software/index.php?title=GPMSWiki/DeveloperDocumentation/DesignDocumentation&amp;diff=2029&amp;oldid=prev"/>
		<updated>2005-08-24T15:28:20Z</updated>

		<summary type="html">&lt;p&gt;&lt;/p&gt;
&lt;table style=&quot;background-color: #fff; color: #202122;&quot; data-mw=&quot;interface&quot;&gt;
				&lt;col class=&quot;diff-marker&quot; /&gt;
				&lt;col class=&quot;diff-content&quot; /&gt;
				&lt;col class=&quot;diff-marker&quot; /&gt;
				&lt;col class=&quot;diff-content&quot; /&gt;
				&lt;tr class=&quot;diff-title&quot; lang=&quot;en&quot;&gt;
				&lt;td colspan=&quot;2&quot; style=&quot;background-color: #fff; color: #202122; text-align: center;&quot;&gt;← Older revision&lt;/td&gt;
				&lt;td colspan=&quot;2&quot; style=&quot;background-color: #fff; color: #202122; text-align: center;&quot;&gt;Revision as of 17:28, 24 August 2005&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot; id=&quot;mw-diff-left-l76&quot;&gt;Line 76:&lt;/td&gt;
&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot;&gt;Line 76:&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;Users and projects are two core objects, every other object is related to&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;Users and projects are two core objects, every other object is related to&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;a specific project or user. Each project specifies a separate well defined scope that&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;a specific project or user. Each project specifies a separate well defined scope that&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;−&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #ffe49c; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;is uniquely identified by its name. Different &lt;del style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;[[&lt;/del&gt;DataSources&lt;del style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;]] &lt;/del&gt;that should be&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;+&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;is uniquely identified by its name. Different DataSources that should be&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;accessed in such a project are referenced by a project which allows&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;accessed in such a project are referenced by a project which allows&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;−&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #ffe49c; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;several projects to share the same &lt;del style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;[[&lt;/del&gt;DataSources&lt;del style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;]]&lt;/del&gt;. In addition to individual&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;+&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;several projects to share the same DataSources. In addition to individual&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;−&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #ffe49c; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;projects a &lt;del style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;[[&lt;/del&gt;MetaProject&lt;del style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;]] &lt;/del&gt;can be used to group&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;+&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;projects a MetaProject can be used to group&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;several project instances to a new project in order to correlate their&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;several project instances to a new project in order to correlate their&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;data.  &lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;data.  &lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;/table&gt;</summary>
		<author><name>imported&gt;JomunaChoudhuri</name></author>
	</entry>
	<entry>
		<id>https://wiki.cebitec.uni-bielefeld.de/brf-software/index.php?title=GPMSWiki/DeveloperDocumentation/DesignDocumentation&amp;diff=2028&amp;oldid=prev</id>
		<title>imported&gt;JomunaChoudhuri at 15:27, 24 August 2005</title>
		<link rel="alternate" type="text/html" href="https://wiki.cebitec.uni-bielefeld.de/brf-software/index.php?title=GPMSWiki/DeveloperDocumentation/DesignDocumentation&amp;diff=2028&amp;oldid=prev"/>
		<updated>2005-08-24T15:27:10Z</updated>

		<summary type="html">&lt;p&gt;&lt;/p&gt;
&lt;p&gt;&lt;b&gt;New page&lt;/b&gt;&lt;/p&gt;&lt;div&gt;__NOTOC__&lt;br /&gt;
= Core Documentation - Design goals and specification =&lt;br /&gt;
&lt;br /&gt;
In this section we describe our concept for a GPMS and specify the basic&lt;br /&gt;
elements. The system design was finally modeled using the Unified Modeling&lt;br /&gt;
Language (UML).&lt;br /&gt;
&lt;br /&gt;
== Basic definitions for a GPMS ==&lt;br /&gt;
For the design of a GPMS several specific elements can be identified that&lt;br /&gt;
represent real world objects or reflect the relationship between&lt;br /&gt;
individual components involved in a project. These core objects are&lt;br /&gt;
defined below in order to clarify their use in the following sections.&lt;br /&gt;
&lt;br /&gt;
=== user ===&lt;br /&gt;
A user simply represents an individual person.&lt;br /&gt;
&lt;br /&gt;
=== project ===&lt;br /&gt;
A project indentifies a specific scope for research or&lt;br /&gt;
ongoing work, e.g. a project can be defined for the annotation of a newly&lt;br /&gt;
sequenced bacterial genome. In most cases a project is defined for and&lt;br /&gt;
related to a special software application, e.g. a genome annotation system.&lt;br /&gt;
&lt;br /&gt;
=== member ===&lt;br /&gt;
A user has to become a member of a project for accessing a&lt;br /&gt;
Project&amp;#039;s data. Thus a project has a number of associated users&lt;br /&gt;
and each user &amp;quot;knows&amp;quot; the projects she/he is involved in.&lt;br /&gt;
&lt;br /&gt;
=== role ===&lt;br /&gt;
The level of access to a Project&amp;#039;s data can be specified by assigning&lt;br /&gt;
well-defined roles to each member. A role thus represents a set of access&lt;br /&gt;
privileges or permissions.&lt;br /&gt;
&lt;br /&gt;
=== gpmsright ===&lt;br /&gt;
Since most database management systems use their own access control&lt;br /&gt;
mechanisms, access is not granted directly based on these privileges. The&lt;br /&gt;
GPMS therefore features the definition of rights as free text&lt;br /&gt;
descriptions that reflect a specific task for which a certain level of data&lt;br /&gt;
access is required (e.g. &amp;quot;basic access&amp;quot; or &amp;quot;annotate&amp;quot;). &lt;br /&gt;
&lt;br /&gt;
=== projectclass ===&lt;br /&gt;
Since all data access control should follow the same rules for every project of the&lt;br /&gt;
same application type, roles and rights are not defined for an&lt;br /&gt;
individual project but for a projectclass.&lt;br /&gt;
&lt;br /&gt;
=== dbprivs ===&lt;br /&gt;
dbprivs represent privileges that are used by a specific RDBMS for controlling&lt;br /&gt;
access to individual databases.&lt;br /&gt;
&lt;br /&gt;
=== datasource ===&lt;br /&gt;
A datasource describes a storage backend for project related&lt;br /&gt;
data that is located on a host (e.g. a database server). This can be either&lt;br /&gt;
a database (DB) stored on a RDBMS or an &lt;br /&gt;
[[ApplicationServer]] that provides data e.g. via web services. A&lt;br /&gt;
DB can be further specified by the type of the database management&lt;br /&gt;
system (DBMS_Type). &lt;br /&gt;
&lt;br /&gt;
=== datasourcetype ===&lt;br /&gt;
A special datasourcetype can be used to determine the specific type of a&lt;br /&gt;
datasource. The datasourcetype contains information about the internal&lt;br /&gt;
structures of a datasource (e.g. tables of a database) and thus all dbprivs&lt;br /&gt;
refer to a corresponding datasourcetype.&lt;br /&gt;
&lt;br /&gt;
=== affiliation ===&lt;br /&gt;
Affiliations allow to associate users and projects with an institution (e.g. CeBiTec). &lt;br /&gt;
In the various web portals (e.g. MGE Portal) at the CeBiTec users may only request access to projects that belong to the same affiliation.&lt;br /&gt;
&lt;br /&gt;
== Specification of the GPMS ==&lt;br /&gt;
Based on the requirements described so far we have designed a GPMS&lt;br /&gt;
that organizes application specific data into projects. We &lt;br /&gt;
have also integrated the administration of users and modeled the relationship&lt;br /&gt;
of users to projects as roles. Figure reffig:design illustrates the central&lt;br /&gt;
components of the gpms and their relationships in UML.&lt;br /&gt;
&lt;br /&gt;
[[Image:GPMSWiki$$DeveloperDocumentation$$DesignDocumentation$GPMS_ClassDiagramWithBorder.png]]&lt;br /&gt;
&lt;br /&gt;
Users and projects are two core objects, every other object is related to&lt;br /&gt;
a specific project or user. Each project specifies a separate well defined scope that&lt;br /&gt;
is uniquely identified by its name. Different [[DataSources]] that should be&lt;br /&gt;
accessed in such a project are referenced by a project which allows&lt;br /&gt;
several projects to share the same [[DataSources]]. In addition to individual&lt;br /&gt;
projects a [[MetaProject]] can be used to group&lt;br /&gt;
several project instances to a new project in order to correlate their&lt;br /&gt;
data. &lt;br /&gt;
&lt;br /&gt;
As another central component users were modeled in a very simple manner:&lt;br /&gt;
They can be identified by their unique login name or email address and are&lt;br /&gt;
thus organized as separate objects. Their individual roles in single projects&lt;br /&gt;
are defined by associating a user, a project, and a role in a member&lt;br /&gt;
object. In order to simplify the assignment of roles we have included an&lt;br /&gt;
additional class (Project_Class) that can be used to group&lt;br /&gt;
projects of the same type (these &lt;br /&gt;
are normally used by the same type of application). Thus roles are only&lt;br /&gt;
defined once for each Project_Class and not individually for each project. A&lt;br /&gt;
role is further associated with a list of rights that specify the level of&lt;br /&gt;
access a user with this role has for a project. Each gpmsright is defined by a&lt;br /&gt;
comprehensive name which explains its semantics. It is associated with&lt;br /&gt;
a list of dbprivs and thus mapped onto specific database privileges&lt;br /&gt;
(e.g. select privilege in SQL). &lt;br /&gt;
&lt;br /&gt;
Author: [http://www.cebitec.uni-bielefeld.de/~lkrause Lutz Krause]&lt;/div&gt;</summary>
		<author><name>imported&gt;JomunaChoudhuri</name></author>
	</entry>
</feed>