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
22:16:43.5822
[info]
Service "Log" is loaded
22:16:43.6082
[info]
Service "Security" is loaded
22:16:43.6098
[info]
Resource "security" is booted
22:16:43.6104
[info]
Service "Database" is loaded
22:16:43.6185
[info]
Resource "database" is booted
22:16:43.6192
[info]
Service "Registry" is loaded
22:16:43.621
[info]
Service "Cache" is loaded
22:16:43.6349
[info]
Resource "config" is booted
22:16:43.6411
[info]
Service "Module" is loaded
22:16:43.6429
[info]
Resource "router" is booted
22:16:43.6446
[info]
Service "I18n" is loaded
22:16:43.6489
[info]
Resource "i18n" is booted
22:16:43.6496
[info]
Resource "module" is booted
22:16:43.6502
[info]
Resource "modules" is booted
22:16:43.651
[info]
Service "Session" is loaded
22:16:43.6755
[info]
Resource "session" is booted
22:16:43.6762
[info]
Service "Authentication" is loaded
22:16:43.6788
[info]
Service "User" is loaded
22:16:43.6808
[info]
Service "Api" is loaded
22:16:43.6853
[info]
Resource "authentication" is booted
22:16:43.6858
[info]
Resource "permission" is booted
22:16:43.6867
[info]
Resource "render_cache" is booted
22:16:43.7127
[info]
Service "Asset" is loaded
22:16:43.7131
[info]
Service "Theme" is loaded
22:16:43.7146
[info]
Translation "module/system:default.en" is loaded.
22:16:43.7188
[info]
Service "Permission" is loaded
22:16:43.72
[info]
Service "RenderCache" is loaded
22:16:43.7238
[info]
Translation "theme/default:default.en" is loaded.
22:16:43.7431
[notice] #2 in module/widget/template/block/carousel/bootstrap.phtml
Undefined index: options
22:16:43.7442
[info]
Translation "module/system:block.en" is loaded.
22:16:43.7455
[info]
Translation "module/system:block.en" is loaded.
22:16:43.7455
[info]
Translation "module/system:block.en" is loaded.
22:16:43.7534
[info]
Service "Form" is loaded
22:16:43.7548
[info]
Service "Url" is loaded
22:16:43.7648
[info]
Translation "module/system:block.en" is loaded.
22:16:43.7657
[info]
Service "View" is loaded
22:16:43.7797
[info]
Route: front:system-index-index.
debug
profiler
22:16:43.582
PI - time: 0.2412; realmem: 4194304; emalloc: 3821776
22:16:43.7202
ACTIION - time: 0.0008; realmem: 0; emalloc: 4392
22:16:43.7391
BLOCKS - time: 0.0235; realmem: 2097152; emalloc: 454704
22:16:43.7418
BLOCK: Pi Highlights - time: 0.0007; realmem: 0; emalloc: 1216
22:16:43.744
BLOCK: Pi feature - time: 0.0012; realmem: 0; emalloc: 1440
22:16:43.7454
BLOCK: User - time: 0.0001; realmem: 0; emalloc: 296
22:16:43.7455
BLOCK: Login - time: 0.0096; realmem: 0; emalloc: 309688
22:16:43.7648
BLOCK: User bar - time: 0.0018; realmem: 0; emalloc: 9480
22:16:43.7707
menu - time: 0.0017; realmem: 0; emalloc: 7448
db
22:16:43.6746
[0.0003]
query: SELECT `core_session`.* FROM `core_session` WHERE `id` = :where1
params: [where1] 43bpemtamhjup6914bf1bklp41;
22:16:43.7406
[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;
22:16:43.7645
[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;
22:16:43.7726
[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;
22:16:43.7799
[0.0002]
query: SELECT `core_session`.* FROM `core_session` WHERE `id` = :where1
params: [where1] 43bpemtamhjup6914bf1bklp41;
22:16:43.7807
[0.0424]
query: INSERT INTO `core_session` (`modified`, `data`, `id`, `lifetime`) VALUES (:modified, :data, :id, :lifetime)
params: [modified] 1532035003;[data] __ZF|a:3:{s:20:"_REQUEST_ACCESS_TIME";d:1532035003.675451;s:6:"_VALID";a:1:{s:36:"Zend\Session\Validator\HttpUserAgent";s:39:"CCBot/2.0 (http://commoncrawl.org/faq/)";}s:33:"Zend_Validator_Csrf_salt_security";a:1:{s:6:"EXPIRE";i:1532035303;}}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:1532035303;}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:"65e0f0ca55098ab66e5f374d9b8e0a8f";s:32:"c89e262c202e85a4b653053a28bc8030";}s:4:"hash";s:65:"c89e262c202e85a4b653053a28bc8030-65e0f0ca55098ab66e5f374d9b8e0a8f";}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] 43bpemtamhjup6914bf1bklp41;[lifetime] 1440;
system
Execution time
0.2535 s
Included files
522 files
Memory usage
4396056; peak: 4594768 bytes
OS
Linux
Web Server
Apache/2
PHP Version
7.0.30
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