friendica/src/Module
2020-01-12 21:07:40 +00:00
..
Admin User lowercase for platform data 2020-01-12 21:07:40 +00:00
Api/Mastodon Update the Introductions domain to use repository, model and collection 2020-01-06 21:39:05 -05:00
Base
Contact
Debug
Diaspora
Filer
HTTPException
Item Remove unused use statements in Module\Item\Compose 2020-01-05 17:09:14 -05:00
Notifications
Profile
Search Move remaining namespaces and delete Core\Cache.php 2020-01-07 00:51:02 +01:00
Security removed some static wrapper 2020-01-07 00:14:01 +01:00
Settings Fix: Show possible managers again 2020-01-10 08:04:48 +00:00
Special
WellKnown
AccountManagementControlDocument.php
Acctlink.php
AllFriends.php
Apps.php
Attach.php
BaseAdminModule.php
BaseSearchModule.php
BaseSettingsModule.php
Bookmarklet.php
Contact.php
Credits.php
Delegation.php
Directory.php
Feed.php
FollowConfirm.php Update the Introductions domain to use repository, model and collection 2020-01-06 21:39:05 -05:00
Followers.php
Following.php
Friendica.php
Group.php
Hashtag.php
Help.php
Home.php
HoverCard.php
Inbox.php
Install.php
Invite.php
Like.php
Magic.php
Maintenance.php
Manifest.php
NodeInfo.php User lowercase for platform data 2020-01-12 21:07:40 +00:00
Objects.php
Oembed.php
OpenSearch.php
Outbox.php
Owa.php
Photo.php
Pinned.php
Profile.php
Proxy.php
PublicRSAKey.php
RandomProfile.php
README.md
ReallySimpleDiscovery.php
Register.php
RobotsTxt.php
Smilies.php
Starred.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.