Documentation for Developers: Difference between revisions

From OpenPetra Wiki
Jump to navigation Jump to search
 
(87 intermediate revisions by 6 users not shown)
Line 1: Line 1:
== How to get started ==
== Projects ==
* [[Setup of Development environment]]
Please read about what needs to be done, and how to take charge of a project here:<br/>
[[Summary of Projects]]


== Software Architecture and Principles ==
 
==Development==
=== Development Environment ===
* [[Quick Setup of Development environment]]
 
=== Programming ===
====General====
* [[Coding Standard and Guidelines]]
* [[Error and Exception Handling Policy]]
* [[Explanation of Directory Structure and Rules]]
 
==== Development ====
* [[Useful hints regarding coding in CSharp/.net]]
* [[Development with Code Generation]]
* [[Development with Code Generation]]
* [[Build system with our own NAnt tools and tasks]]
* [[Preventing/getting around circular dependency problems]]
==== Database-related====
* Architecture Information
** [[Overview openPETRA architecture#Database_System|Database System]] / [[Database access architecture]]
** Two diagrams at the right ------------------------------>
[[File:OpenPETRA_Data_RDBMS_Abstraction_only_Diagram.png|200px|thumb|right|openPETRA Database Abstraction Layer Diagram]]
[[File:Petra_NET_Data_Access_Layer.png|200px|thumb|right|Data Access Layer]]
* [[Using OpenPetra's DataAccess Objects]]
* [[DB Access Exception Handling]]
* [[Automatic DB Transaction Handling]]
* [[Co-ordinated DB Access (Thread-safe DB Access)]]
* [[Working with multiple DB Connections]]
* [[Stopping of Running DB Queries]]
* [['Preparing' SQL Statements And Specifying SQL Statement Time-outs]]
* [[Specifying 'standard' / 'default' / 'base' data for DB Tables]]
* [[DataSets: Ensuring you deliver 'unchanged' data to the Client]]
* PostgreSQL-specifics
** [[PostgreSQL: Sequences Not Tied to DB Transactions]]
====Other Topics====
* [[User Defaults]]
* [[System Settings (Maintain Table Screen)]]
* [[Working with OpenPetra Security]]
* [[Retrieving the 'SiteKey' of an OpenPetra installation]]
=== Development Cycle ===
* [[Build System for OpenPetra]]
* [[Releases and Patching]]
* [[Building and maintaining customized versions of OpenPetra]]
* [[Migrating data from legacy systems]]
* [[Working with NUnit tests]]
=== Getting Started ===
* [[HowTo develop a new screen]]
* [[HowTo develop a new report]]
* [[Report Designer]]
=== Tools Used ===
This is a list of software that we use; some of it you will already have installed when you did your [[Setup of Development environment]].
* [[Software tools for Developers]]
* [[Memory profiling]]
=== Tips and Tricks ===
* [[Specifying custom settings in Config Files for Development]]
* [[Developing the Javascript Client]]
* [[Homepage]]
== OpenPetra Software Architecture ==
* [[Overview openPETRA architecture]]
** Taken from the old Petra wiki. Should be merged with the other articles!
* [[n-tier architecture]]
* [[n-tier architecture]]
* [[Database access architecture]]
* [[Database access architecture]]
* [[GUI development]]


== Projects ==
=== Client Side ===
It is probably good to manage the projects, todo lists, feature requests, and bugs all in one place, also called a tracker. We use Mantis for that. A quick link is: http://tracker.openpetra.org
* [[Printing]]
* Specific Screens
** [[Exchange Rates (Design and Test)]]
 
== Bug Tracking ==
See [[Contributing_Source_Code_to_OpenPetra.org#Tracking_of_Bugs_and_Things_to_do|Tracking of Bugs]]


Everyone can report issues (we will revise that if the spam becomes too much...).


For discussion, it might be useful to have those discussions in the forum.
== Database Structure Documentation ==
We have DB model documentation online available in two formats, both of which are auto-generated with each release:
* [http://openpetraorg.sourceforge.net/dbdoc/index.html Our own format] (see also [[SQL Diagram creation]])
** There is a [http://openpetraorg.sourceforge.net/dbdoc/img/img_AccountsPayable.html?a_ap_document diagram for the Accounts Payable sub system]
*** We need volunteers do design more diagrams! Please also have a look at the old 2.1 diagrams ([http://openpetraorg.sourceforge.net/Petra21DBDiagrams.zip download 9 png files in a zip file]).
* [http://openpetraorg.sourceforge.net/schemaSpy/index.html SchemaSpy format]
** features quite nice automatically drawn relationship diagrams once you select a certain DB table. That can also be shown for the whole DB if you simply go to the ‘Relationships’ Tab on the index page (though that diagram is HUGE as the OpenPetra DB currently holds >300 DB Tables!).


For technical details of an implementation, we should document that here in the wiki.


A summary and explanation of some projects that need work can be found here: [[Summary of Projects]]
* [[Base and Demo databases]]
* [[Specifying 'standard' / 'default' / 'base' data for DB Tables]]


== Used Tools ==
== Project Infrastructure ==
This is a list of software that we use; some of it you will already have installed when you did your [[Setup of Development environment]].
* Have a look at [[wordpress]]. The OpenPetra Website is running on Wordpress.
* [[Software tools for Developers]]
* Continuous integration with [[Continuous Integration with LightBuildServer|LightBuildServer]]
* [[Branches and Releases of OpenPetra]]

Latest revision as of 21:04, 11 Mayıs 2022

Projects

Please read about what needs to be done, and how to take charge of a project here:
Summary of Projects


Development

Development Environment

Programming

General

Development

Database-related

openPETRA Database Abstraction Layer Diagram
Data Access Layer

Other Topics

Development Cycle

Getting Started

Tools Used

This is a list of software that we use; some of it you will already have installed when you did your Setup of Development environment.

Tips and Tricks

OpenPetra Software Architecture

Client Side

Bug Tracking

See Tracking of Bugs


Database Structure Documentation

We have DB model documentation online available in two formats, both of which are auto-generated with each release:


Project Infrastructure