friendica/src/Module
2023-03-19 18:52:45 +01:00
..
ActivityPub
Admin Takahē and Wildebeest added, Nomad detection improved 2023-03-18 11:43:29 +00:00
Api Fix paging on List and Public timelines honoring order type 2023-03-17 22:13:43 -04:00
Blocklist/Domain
Calendar
Contact
Conversation
Debug
DFRN
Diaspora
Filer
HTTPException
Item take maxFilesize from systemsettings 2023-03-19 18:52:45 +01:00
Media Prevent template generation in media/attachment/upload output 2023-03-16 21:14:07 -04:00
Moderation
Notifications
OAuth
OStatus
Post fix missing DI 2023-03-19 18:52:45 +01:00
Profile
Search
Security
Settings Option to automatically add links as attachment via API 2023-03-13 21:30:20 +00:00
Special
Update
User
WellKnown
About.php
AccountManagementControlDocument.php
Acctlink.php
Apps.php
Attach.php
BaseAdmin.php
BaseApi.php
BaseModeration.php
BaseNotifications.php
BaseProfile.php
BaseSearch.php
BaseSettings.php
Bookmarklet.php
Contact.php
Credits.php
Delegation.php
Directory.php
Feed.php
FollowConfirm.php
Friendica.php
FriendSuggest.php
Group.php
Hashtag.php
HCard.php
Help.php
Home.php
Install.php
Invite.php
Magic.php
Maintenance.php
Manifest.php
NodeInfo110.php
NodeInfo120.php
NodeInfo210.php
NoScrape.php
Oembed.php
OpenSearch.php
Owa.php
ParseUrl.php
PermissionTooltip.php
Photo.php
Proxy.php
PublicRSAKey.php
RandomProfile.php
README.md
ReallySimpleDiscovery.php
Register.php
Response.php
RobotsTxt.php
Smilies.php
Statistics.php
Theme.php
ThemeDetails.php
ToggleMobile.php
Tos.php
Welcome.php
Xrd.php

Friendica\Module

The Module namespace contains the different modules of Friendica. Each module is loaded through the App.

There are mainly two types of modules:

  • frontend modules to interact with users
  • backend modules to interact with machine requests

Frontend modules

This type of modules mainly needs a template, which are generally located at view/templates/.

A frontend module should extend the BaseModule, especially the content() method.

Backend modules

This type of modules mainly responds either with encoded XML or with JSON output. It isn't intended to respond with human readable text.

A frontend module should extend the BaseModule, especially the rawContent() method.

Routing

Every module needs to be accessed within a route. The routes are defined inside Router->collectRoutes().

Use the given routes as a pattern for further routes.

The routing library and further documentation can be found here.