Pi Highlights

Pi feature

Pi Engine is a role oriented application development engine for web and mobile, designed as the next generation and a successor to Xoops. Pi is developed upon PHP and MySQL with selected third-party frameworks including but not limited to Zend Framework library, jQuery, Bootstrap and Backbone.

Pi Project follows the philosophy of open standard, open design, open development and open structure. Pi is born as a complete open source project and intended to build a sustainable ecosystem that benefits all contributors and users.

The Engine is released under a BSD 3-Clause License.

Selected features and practices:
  1. Modularization for functionality and applications
  2. Components for basic libraries and services for fundamental system functions
  3. Theming for presentation and appearance
  4. Design-friendly templating
  5. DevOps oriented architecture
  6. Centralized security enhancement
Quick start:

Login

log(37) | debug(0) | profiler(9) | db(6) | system(13) | all
log
12:53:20.0881
[info]
Service "Log" is loaded
12:53:20.1016
[info]
Service "Security" is loaded
12:53:20.1027
[info]
Resource "security" is booted
12:53:20.1033
[info]
Service "Database" is loaded
12:53:20.1083
[info]
Resource "database" is booted
12:53:20.1089
[info]
Service "Registry" is loaded
12:53:20.1098
[info]
Service "Cache" is loaded
12:53:20.1171
[info]
Resource "config" is booted
12:53:20.1208
[info]
Service "Module" is loaded
12:53:20.1223
[info]
Resource "router" is booted
12:53:20.1229
[info]
Service "I18n" is loaded
12:53:20.1259
[info]
Resource "i18n" is booted
12:53:20.1265
[info]
Resource "module" is booted
12:53:20.1273
[info]
Resource "modules" is booted
12:53:20.1278
[info]
Service "Session" is loaded
12:53:20.1498
[info]
Resource "session" is booted
12:53:20.1504
[info]
Service "Authentication" is loaded
12:53:20.1518
[info]
Service "User" is loaded
12:53:20.1527
[info]
Service "Api" is loaded
12:53:20.154
[info]
Resource "authentication" is booted
12:53:20.1543
[info]
Resource "permission" is booted
12:53:20.1545
[info]
Resource "render_cache" is booted
12:53:20.1699
[info]
Service "Asset" is loaded
12:53:20.1702
[info]
Service "Theme" is loaded
12:53:20.1738
[info]
Translation "module/system:default.en" is loaded.
12:53:20.1763
[info]
Service "Permission" is loaded
12:53:20.1773
[info]
Service "RenderCache" is loaded
12:53:20.181
[info]
Translation "theme/default:default.en" is loaded.
12:53:20.1938
[notice] #2 in module/widget/template/block/carousel/bootstrap.phtml
Undefined index: options
12:53:20.1952
[info]
Translation "module/system:block.en" is loaded.
12:53:20.1959
[info]
Translation "module/system:block.en" is loaded.
12:53:20.196
[info]
Translation "module/system:block.en" is loaded.
12:53:20.1997
[info]
Service "Form" is loaded
12:53:20.2007
[info]
Service "Url" is loaded
12:53:20.2103
[info]
Translation "module/system:block.en" is loaded.
12:53:20.2112
[info]
Service "View" is loaded
12:53:20.2247
[info]
Route: front:system-index-index.
debug
profiler
12:53:20.0879
PI - time: 0.2457; realmem: 2097152; emalloc: 2738872
12:53:20.1776
ACTIION - time: 0.0006; realmem: 0; emalloc: 4032
12:53:20.1909
BLOCKS - time: 0.0171; realmem: 0; emalloc: 381304
12:53:20.1931
BLOCK: Pi Highlights - time: 0.0002; realmem: 0; emalloc: 1120
12:53:20.1949
BLOCK: Pi feature - time: 0.0005; realmem: 0; emalloc: 1328
12:53:20.1959
BLOCK: User - time: 0.0001; realmem: 0; emalloc: 296
12:53:20.196
BLOCK: Login - time: 0.0052; realmem: 0; emalloc: 175808
12:53:20.2102
BLOCK: User bar - time: 0.0019; realmem: 0; emalloc: 9176
12:53:20.2135
menu - time: 0.0025; realmem: 0; emalloc: 7136
db
12:53:20.142
[0.0073]
query: SELECT `core_session`.* FROM `core_session` WHERE `id` = :where1
params: [where1] jovebk1jg8d5i0h5gclk9rkmmn;
12:53:20.1922
[0.0005]
query: SELECT `core_block`.`id` AS `id`, `core_block`.`root` AS `root`, `core_block`.`name` AS `name`, `core_block`.`title` AS `title`, `core_block`.`description` AS `description`, `core_block`.`module` AS `module`, `core_block`.`template` AS `template`, `core_block`.`render` AS `render`, `core_block`.`config` AS `config`, `core_block`.`type` AS `type`, `core_block`.`content` AS `content`, `core_block`.`cache_ttl` AS `cache_ttl`, `core_block`.`cache_level` AS `cache_level`, `core_block`.`title_hidden` AS `title_hidden`, `core_block`.`body_fullsize` AS `body_fullsize`, `core_block`.`active` AS `active`, `core_block`.`cloned` AS `cloned`, `core_block`.`class` AS `class`, `core_block`.`subline` AS `subline` FROM `core_block` WHERE `id` IN (:where1, :where2, :where3, :where4)
params: [where1] 6;[where2] 5;[where3] 2;[where4] 4;
12:53:20.2098
[0.0003]
query: SELECT `core_block`.`id` AS `id`, `core_block`.`root` AS `root`, `core_block`.`name` AS `name`, `core_block`.`title` AS `title`, `core_block`.`description` AS `description`, `core_block`.`module` AS `module`, `core_block`.`template` AS `template`, `core_block`.`render` AS `render`, `core_block`.`config` AS `config`, `core_block`.`type` AS `type`, `core_block`.`content` AS `content`, `core_block`.`cache_ttl` AS `cache_ttl`, `core_block`.`cache_level` AS `cache_level`, `core_block`.`title_hidden` AS `title_hidden`, `core_block`.`body_fullsize` AS `body_fullsize`, `core_block`.`active` AS `active`, `core_block`.`cloned` AS `cloned`, `core_block`.`class` AS `class`, `core_block`.`subline` AS `subline` FROM `core_block` WHERE `name` = :where1
params: [where1] system-user-bar;
12:53:20.2162
[0.0002]
query: SELECT `core_block`.`id` AS `id`, `core_block`.`root` AS `root`, `core_block`.`name` AS `name`, `core_block`.`title` AS `title`, `core_block`.`description` AS `description`, `core_block`.`module` AS `module`, `core_block`.`template` AS `template`, `core_block`.`render` AS `render`, `core_block`.`config` AS `config`, `core_block`.`type` AS `type`, `core_block`.`content` AS `content`, `core_block`.`cache_ttl` AS `cache_ttl`, `core_block`.`cache_level` AS `cache_level`, `core_block`.`title_hidden` AS `title_hidden`, `core_block`.`body_fullsize` AS `body_fullsize`, `core_block`.`active` AS `active`, `core_block`.`cloned` AS `cloned`, `core_block`.`class` AS `class`, `core_block`.`subline` AS `subline` FROM `core_block` WHERE `name` = :where1
params: [where1] search-search;
12:53:20.2249
[0.0002]
query: SELECT `core_session`.* FROM `core_session` WHERE `id` = :where1
params: [where1] jovebk1jg8d5i0h5gclk9rkmmn;
12:53:20.2255
[0.1079]
query: INSERT INTO `core_session` (`modified`, `data`, `id`, `lifetime`) VALUES (:modified, :data, :id, :lifetime)
params: [modified] 1580216000;[data] __ZF|a:3:{s:20:"_REQUEST_ACCESS_TIME";d:1580216000.14972;s:6:"_VALID";a:1:{s:36:"Zend\Session\Validator\HttpUserAgent";s:40:"CCBot/2.0 (https://commoncrawl.org/faq/)";}s:33:"Zend_Validator_Csrf_salt_security";a:1:{s:6:"EXPIRE";i:1580216300;}}PI_USER|a:2:{s:5:"field";a:3:{s:2:"id";i:0;s:8:"identity";s:0:"";s:4:"name";s:5:"Guest";}s:4:"time";i:1580216300;}Zend_Validator_Csrf_salt_security|C:23:"Zend\Stdlib\ArrayObject":391:{a:4:{s:7:"storage";a:2:{s:9:"tokenList";a:1:{s:32:"52fd907c798edcdaaf12a9c02ab330b3";s:32:"5627f3e9e9e0fc5986b947031dcb6345";}s:4:"hash";s:65:"5627f3e9e9e0fc5986b947031dcb6345-52fd907c798edcdaaf12a9c02ab330b3";}s:4:"flag";i:2;s:13:"iteratorClass";s:13:"ArrayIterator";s:19:"protectedProperties";a:4:{i:0;s:7:"storage";i:1;s:4:"flag";i:2;s:13:"iteratorClass";i:3;s:19:"protectedProperties";}}}FlashMessenger|C:23:"Zend\Stdlib\ArrayObject":205:{a:4:{s:7:"storage";a:0:{}s:4:"flag";i:2;s:13:"iteratorClass";s:13:"ArrayIterator";s:19:"protectedProperties";a:4:{i:0;s:7:"storage";i:1;s:4:"flag";i:2;s:13:"iteratorClass";i:3;s:19:"protectedProperties";}}};[id] jovebk1jg8d5i0h5gclk9rkmmn;[lifetime] 1440;
system
Execution time
0.2513 s
Included files
523 files
Memory usage
3248072; peak: 3248104 bytes
OS
Linux
Web Server
LiteSpeed
PHP Version
7.1.33
Pi Environment
2.6.0-alpha development
Zend Version
2.4.11
Persist Engine
memcached
Cache Storage
Pi\Cache\Storage\Adapter\Filesystem
Module
system
Theme
default
Extensions
APC: ; Intl; cURL