friendica/src/Module
2019-05-05 19:06:51 +02:00
..
Admin
Diaspora
Special
WellKnown
AccountManagementControlDocument.php
Acctlink.php
AllFriends.php
Apps.php
Attach.php
Babel.php
BaseAdminModule.php Fix EOL and EOF in Admin modules 2019-05-02 09:55:50 -04:00
BookMarklet.php
Contact.php
Credits.php
Directory.php
Feed.php
Feedtest.php
Filer.php
Followers.php
Following.php
Group.php
Hashtag.php
Help.php
Home.php
Inbox.php
Install.php
Invite.php
Itemsource.php
Like.php
Localtime.php
Login.php
Logout.php
Magic.php
Manifest.php
NodeInfo.php
Objects.php
Oembed.php
Outbox.php
Owa.php
PageNotFound.php
Photo.php
Profile.php
Proxy.php
README.md
ReallySimpleDiscovery.php
Register.php
RobotsTxt.php Move mod/robots_txt to src/Module/RobotsTxt 2019-05-05 19:06:51 +02:00
Statistics.php
Tos.php
WebFinger.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.