phpList is an open source newsletter manager. This project is a rewrite of the original phpList.
This is the core module of the successor to phpList 3. It will have the following responsibilities:
- provide access to the DB via Doctrine models and repositories (and raw SQL for performance-critical parts that do not need the models)
- routing (which the web frontend and REST API will use)
- authentication (which the web frontend and REST API will use)
- logging
- a script for tasks to be called from the command line (or a cron job)
- tasks to create and update the DB schema
Please note that this module does not provide a web frontend or a REST API.
There are the separate modules phpList/web-frontend
and phpList/rest-api
for these tasks.
This module should not be modified locally. It should be updated via Composer.
Please install this package via Composer from within the phpList base distribution, which also has more detailed installation instructions in the README.
Please read the contribution guide on how to contribute and how to run the unit tests and style checks locally.
This project adheres to a Contributor Code of Conduct. By participating in this project and its community, you are expected to uphold this code.
The phpList application is configured so that the built-in PHP web server can run in development and testing mode, while Apache can run in production mode.
Please first set the database credentials in config/parameters.yml
.
For running the application in development mode using the built-in PHP server, use this command:
bin/console server:run -d public/
The server will then listen on http://127.0.0.1:8000
(or, if port 8000 is
already in use, on the next free port after 8000).
You can stop the server with CTRL + C.
Running tests requires that necessary composer packages, such as PHPUnit, are
first installed for this repository. If you installed core
using the
base-distribution
package, then you must install the composer packages
separately. To do so, change to the base directory of core
and run
composer install
.
See .travis.yml
for commands to run various PHPUnit test suites.
To run the server in testing mode (which normally will only be needed for the
automated tests, provide the --env
option:
bin/console server:run -d public/ --env=test
For documentation on running the application in production mode using Apache, please see the phpList base distribution README.
Any changes to the database schema must always be done both in phpList 3 and later versions so that both versions always have the same schema.
For changing the database schema, please edit resources/Database/Schema.sql
and adapt the corresponding domain model classes and repository classes
accordingly.
In phpList, plugins are called modules. They are Composer packages which
have the type phplist-module
.
If your module provides any Symfony bundles, the bundle class names need to be
listed in the extra
section of the module's composer.json
like this:
"extra": {
"phplist/core": {
"bundles": [
"Symfony\\Bundle\\FrameworkBundle\\FrameworkBundle",
"PhpList\\Core\\EmptyStartPageBundle\\PhpListEmptyStartPageBundle"
]
}
}
Please note that the key of the section with extra
needs to always be
phplist/core
, not the name of your module package. Please have a
look at the
composer.json
in the rest-api
module
for an example.
Similarly, if your module provides any routes, those also need to be listed in
the extra
section of the module's composer.json
like this:
"extra": {
"phplist/core": {
"routes": {
"homepage": {
"resource": "@PhpListEmptyStartPageBundle/Controller/",
"type": "annotation"
}
}
}
}
You can also provide system configuration for your module:
"extra": {
"phplist/core": {
"configuration": {
"framework": {
"templating": {
"engines": [
"twig"
]
}
}
}
}
}
It is recommended to define the routes using annotations in the controller classes so that the route configuration in the composer.json is minimal.
For accessing the phpList database tables from a module, please use the
Doctrine model and repository classes
stored in src/Domain/
in the phplist/core
package (this
package).
For accessing a repository, please have it injected via dependency injection. Please do not get the repository directly from the entity manager as this would skip dependency injection for that repository, causing those methods to break that rely on other services having been injected.
Currently, only a few database tables are mapped as models/repositories. If you need a mode or a repository method that still is missing, please submit a pull request or file an issue.
To access the phpList data from a third-party application (i.e., not from a phpList module), please use the REST API.
phpList is copyright (C) 2000-2018 phpList Ltd.