annotate vendor/psy/psysh/src/TabCompletion/Matcher/MongoDatabaseMatcher.php @ 13:5fb285c0d0e3

Update Drupal core to 8.4.7 via Composer. Security update; I *think* we've been lucky to get away with this so far, as we don't support self-registration which seems to be used by the so-called "drupalgeddon 2" attack that 8.4.5 was vulnerable to.
author Chris Cannam
date Mon, 23 Apr 2018 09:33:26 +0100
parents
children 129ea1e6d783
rev   line source
Chris@13 1 <?php
Chris@13 2
Chris@13 3 /*
Chris@13 4 * This file is part of Psy Shell.
Chris@13 5 *
Chris@13 6 * (c) 2012-2018 Justin Hileman
Chris@13 7 *
Chris@13 8 * For the full copyright and license information, please view the LICENSE
Chris@13 9 * file that was distributed with this source code.
Chris@13 10 */
Chris@13 11
Chris@13 12 namespace Psy\TabCompletion\Matcher;
Chris@13 13
Chris@13 14 /**
Chris@13 15 * A MongoDB tab completion Matcher.
Chris@13 16 *
Chris@13 17 * This matcher provides completion for Mongo collection names.
Chris@13 18 *
Chris@13 19 * @author Marc Garcia <markcial@gmail.com>
Chris@13 20 */
Chris@13 21 class MongoDatabaseMatcher extends AbstractContextAwareMatcher
Chris@13 22 {
Chris@13 23 /**
Chris@13 24 * {@inheritdoc}
Chris@13 25 */
Chris@13 26 public function getMatches(array $tokens, array $info = [])
Chris@13 27 {
Chris@13 28 $input = $this->getInput($tokens);
Chris@13 29
Chris@13 30 $firstToken = array_pop($tokens);
Chris@13 31 if (self::tokenIs($firstToken, self::T_STRING)) {
Chris@13 32 // second token is the object operator
Chris@13 33 array_pop($tokens);
Chris@13 34 }
Chris@13 35 $objectToken = array_pop($tokens);
Chris@13 36 $objectName = str_replace('$', '', $objectToken[1]);
Chris@13 37 $object = $this->getVariable($objectName);
Chris@13 38
Chris@13 39 if (!$object instanceof \MongoDB) {
Chris@13 40 return [];
Chris@13 41 }
Chris@13 42
Chris@13 43 return array_filter(
Chris@13 44 $object->getCollectionNames(),
Chris@13 45 function ($var) use ($input) {
Chris@13 46 return AbstractMatcher::startsWith($input, $var);
Chris@13 47 }
Chris@13 48 );
Chris@13 49 }
Chris@13 50
Chris@13 51 /**
Chris@13 52 * {@inheritdoc}
Chris@13 53 */
Chris@13 54 public function hasMatched(array $tokens)
Chris@13 55 {
Chris@13 56 $token = array_pop($tokens);
Chris@13 57 $prevToken = array_pop($tokens);
Chris@13 58
Chris@13 59 switch (true) {
Chris@13 60 case self::tokenIs($token, self::T_OBJECT_OPERATOR):
Chris@13 61 case self::tokenIs($prevToken, self::T_OBJECT_OPERATOR):
Chris@13 62 return true;
Chris@13 63 }
Chris@13 64
Chris@13 65 return false;
Chris@13 66 }
Chris@13 67 }