diff options
author | Thomas Müller <thomas.mueller@tmit.eu> | 2015-01-28 22:08:50 +0100 |
---|---|---|
committer | Thomas Müller <thomas.mueller@tmit.eu> | 2015-02-10 11:51:24 +0100 |
commit | d74662df7df72ad9ec238b78223acc0e7f65311f (patch) | |
tree | ffadb56b1bb0c0dfa11cb54a10a67186aff31306 /core/command | |
parent | 5ae03fd650b6f3665d1c69ead674d4f5d6420513 (diff) | |
download | nextcloud-server-d74662df7df72ad9ec238b78223acc0e7f65311f.tar.gz nextcloud-server-d74662df7df72ad9ec238b78223acc0e7f65311f.zip |
implement php code checker to detect usage of not allowed private APIs - including console command to check local code to be used by developers
Diffstat (limited to 'core/command')
-rw-r--r-- | core/command/app/checkcode.php | 53 |
1 files changed, 53 insertions, 0 deletions
diff --git a/core/command/app/checkcode.php b/core/command/app/checkcode.php new file mode 100644 index 00000000000..55c30b900b3 --- /dev/null +++ b/core/command/app/checkcode.php @@ -0,0 +1,53 @@ +<?php +/** + * Copyright (c) 2015 Thomas Müller <deepdiver@owncloud.com> + * This file is licensed under the Affero General Public License version 3 or + * later. + * See the COPYING-README file. + */ + +namespace OC\Core\Command\App; + +use Symfony\Component\Console\Command\Command; +use Symfony\Component\Console\Input\InputArgument; +use Symfony\Component\Console\Input\InputInterface; +use Symfony\Component\Console\Output\OutputInterface; + +class CheckCode extends Command { + protected function configure() { + $this + ->setName('app:check-code') + ->setDescription('check code to be compliant') + ->addArgument( + 'app-id', + InputArgument::REQUIRED, + 'enable the specified app' + ); + } + + protected function execute(InputInterface $input, OutputInterface $output) { + $appId = $input->getArgument('app-id'); + $codeChecker = new \OC\App\CodeChecker(); + $codeChecker->listen('CodeChecker', 'analyseFileBegin', function($params) use ($output) { + $output->writeln("<info>Analysing {$params}</info>"); + }); + $codeChecker->listen('CodeChecker', 'analyseFileFinished', function($params) use ($output) { + $count = count($params); + $output->writeln(" {$count} errors"); + usort($params, function($a, $b) { + return $a['line'] >$b['line']; + }); + + foreach($params as $p) { + $line = sprintf("%' 4d", $p['line']); + $output->writeln(" <error>line $line: {$p['disallowedToken']} - {$p['reason']}</error>"); + } + }); + $errors = $codeChecker->analyse($appId); + if (empty($errors)) { + $output->writeln('<info>App is compliant - awesome job!</info>'); + } else { + $output->writeln('<error>App is not compliant</error>'); + } + } +} |