forked from GNUsocial/gnu-social
		
	[DOCS] Elaborate initial architecture page
This commit is contained in:
		| @@ -1,16 +1,23 @@ | ||||
| # Summary | ||||
|  | ||||
| - [High level view](./high_level.md) | ||||
| - [Architecture and Paradigms](./architecture.md) | ||||
| - [Database](./database.md) | ||||
| - [Architecture: Modules](./architecture.md) | ||||
|     - [Programming Style](./paradigms.md) | ||||
|     - [Events](./events.md) | ||||
|     - [Database](./database.md) | ||||
|     - [Cache](./cache.md) | ||||
|     - [Routes and Controllers](./routes_and_controllers.md) | ||||
|     - [Templates](./templates.md) | ||||
|     - [Internationalization](./internationalization.md) | ||||
|     - [Log](./log.md) | ||||
|     - [Queues](./queues.md) | ||||
|     - [Files](./files.md) | ||||
|     - [Security](./security.md) | ||||
|     - [HTTP](./http.md) | ||||
| - [Plugins](./plugins.md) | ||||
|     - [Event Handlers](./plugins/no_docker_shell.md) | ||||
|     - [Installation](./plugins/docker_web.md) | ||||
|     - [Configuration](./plugins/configuration.md) | ||||
|     - [Initialization and Clean Up](./plugins/lifetime.md) | ||||
|     - [Database](./plugins/database.md) | ||||
|     - [Routes and Controllers](./plugins/routes_and_controllers.md) | ||||
|     - [Events](./plugins/events.md) | ||||
| - [Sample Plugins](./sample_plugins.md) | ||||
|     - [Injecting Javascript](plugins/sample_plugins/Awesomeness.md) | ||||
|     - [Creating a block on the sidebar](plugins/sample_plugins/Sample.md) | ||||
| - [Components](./components.md) | ||||
|   | ||||
| @@ -0,0 +1,83 @@ | ||||
| # Architecture: Modules | ||||
|  | ||||
| ## Core | ||||
|  | ||||
| The `core` tries to be minimal. The essence of it being various wrappers around Symfony. It provides: | ||||
|  | ||||
| - the Module system described in this chapter; | ||||
| - [Events](./events.md); | ||||
| - data representation via an [Object-relational database](https://en.wikipedia.org/wiki/Object%E2%80%93relational_database), | ||||
| which is elaborated in [Database](./database.md); | ||||
| - [Cache](./cache.md); | ||||
| - [Routes and Controllers](./routes_and_controllers.md); | ||||
| - [Templates](./templates.md); | ||||
| - [Internationalization (i18n)](https://en.wikipedia.org/wiki/Internationalization_and_localization), elaborated in [Internationalization](internationalization.md); | ||||
| - [Log](./log.md); | ||||
| - [Queues](./queues.md); | ||||
| - [Files](./files.md); | ||||
| - [Security](./security.md); | ||||
| - [HTTP Client](./http.md). | ||||
|  | ||||
| Everything else uses most of this. | ||||
|  | ||||
| ## Modules | ||||
| The GNU social [Component-based architecture](https://en.wikipedia.org/wiki/Component-based_software_engineering) | ||||
| provides a clear distinction between what can not be changed (**[core](http://foldoc.org/core)**), what is replaceable | ||||
| but must be always present (**[component](http://foldoc.org/component)**), and what can be removed or | ||||
| added (**[plugin](http://foldoc.org/plugin)**). | ||||
|  | ||||
| This architecture has terminology differences when compared to the one that was [introduced in v2](https://agile.gnusocial.rocks/doku.php?id=v2modules). | ||||
| In fact, back in v2 - as the term `modules` is not necessarily non-essential - we would keep a "modules" directory near | ||||
| "plugins", to make the intended difference between both self-evident. | ||||
|  | ||||
| Now in v3, **[Module](http://foldoc.org/module)** is the name we give to the core system managing all the `modules` (as | ||||
| it is broad enough to include both components and plugins). N.B.: there are not `modules` in the same sense as | ||||
| there are `components` and `plugins`, the latter descend from the former. | ||||
|  | ||||
| ### Components | ||||
|  | ||||
| The most fundamental modules are the components. These are non-core functionality expected to be always available. | ||||
| Unlike the core, it can be exchanged with equivalent components. | ||||
|  | ||||
| We have components for two key reasons: | ||||
| - to make available internal higher level APIs, i.e. more abstract ways of interacting with the Core; | ||||
| - to implement all the basic/essential GNU social functionality in the very same way we would implement plugins.  | ||||
|  | ||||
| Currently, GNU social has the following components: | ||||
|  | ||||
| - Avatar | ||||
| - Posting | ||||
|  | ||||
| ### Plugins (Unix Tools Design Philosophy) | ||||
|  | ||||
| GNU social is true to the Unix-philosophy of small programs to do a small job. | ||||
|  | ||||
| > * Compact and concise input syntax, making full use of ASCII repertoire to minimise keystrokes; | ||||
| > * Output format should be simple and easily usable as input for other programs; | ||||
| > * Programs can be joined together in “pipes” and “scripts” to solve more complex problems; | ||||
| > * Each tool originally performed a simple single function; | ||||
| > * Prefer reusing existing tools with minor extension to rewriting a new tool from scratch; | ||||
| > * The main user-interface software (“shell”) is a normal replaceable program without special privileges; | ||||
| > * Support for automating routine tasks. | ||||
| > | ||||
| > Brian W. Kernighan, Rob Pike: The Unix Programming Environment. Prentice-Hall, 1984. | ||||
|  | ||||
| For instructions on how to implement a plugin and use the core functionality check the [Plugins chapter](./plugins.md). | ||||
|  | ||||
| ## Dependencies | ||||
|  | ||||
| * The Core only depends on Symfony. We wrote wrappers for all the Symfony functionality we use, making it possible to | ||||
|   replace Symfony in the future if needed and to make it usable under our | ||||
|   [programming paradigms, philosophies and conventions](./paradigms.md). V2 tried to do this with PEAR. | ||||
| * Components only depend on the Core. The Core never depends on Components. | ||||
| * Components never have inter-dependencies. | ||||
| * Plugins can depend both on the Core and on Components. | ||||
| * A plugin may recognize other plugin existence and provide extra functionality via events. | ||||
|  | ||||
| N.B.: "depend on" and "allowing to" have different implications. A plugin can throw an event and other plugins may | ||||
| handle such event. On the other hand, it's **wrong** if: | ||||
| * two plugins are inter-dependent in order to provide all of their useful functionality - consider adding [configuration to your plugin](./plugins/configuration.md); | ||||
| * a component depends on or handles events from plugins - consider throwing an event from your component replacement and | ||||
|   then handling it from a plugin. | ||||
|  | ||||
| This "hierarchy" makes the flow of things perceivable and predictable, that helps to maintain sanity. | ||||
							
								
								
									
										0
									
								
								docs/developer/src/paradigms.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										0
									
								
								docs/developer/src/paradigms.md
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | ||||
| # Developing Plugins | ||||
|   | ||||
							
								
								
									
										0
									
								
								docs/developer/src/routes_and_controllers.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										0
									
								
								docs/developer/src/routes_and_controllers.md
									
									
									
									
									
										Normal file
									
								
							
							
								
								
									
										0
									
								
								docs/developer/src/security.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										0
									
								
								docs/developer/src/security.md
									
									
									
									
									
										Normal file
									
								
							
							
								
								
									
										0
									
								
								docs/developer/src/templates.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										0
									
								
								docs/developer/src/templates.md
									
									
									
									
									
										Normal file
									
								
							
		Reference in New Issue
	
	Block a user