+++ /dev/null
-<?php
-
-/**
- * @file
- * Contains \Drupal\Console\Core\Command\Yaml\UpdateValueCommand.
- */
-
-namespace Drupal\Console\Core\Command\Yaml;
-
-use Symfony\Component\Console\Input\InputArgument;
-use Symfony\Component\Console\Input\InputInterface;
-use Symfony\Component\Console\Output\OutputInterface;
-use Symfony\Component\Yaml\Dumper;
-use Symfony\Component\Yaml\Parser;
-use Symfony\Component\Console\Command\Command;
-use Drupal\Console\Core\Command\Shared\CommandTrait;
-use Drupal\Console\Core\Style\DrupalStyle;
-use Drupal\Console\Core\Utils\NestedArray;
-
-class UpdateValueCommand extends Command
-{
- use CommandTrait;
-
- /**
- * @var NestedArray
- */
- protected $nestedArray;
-
- /**
- * UpdateValueCommand constructor.
- *
- * @param NestedArray $nestedArray
- */
- public function __construct(NestedArray $nestedArray)
- {
- $this->nestedArray = $nestedArray;
- parent::__construct();
- }
-
- protected function configure()
- {
- $this
- ->setName('yaml:update:value')
- ->setDescription($this->trans('commands.yaml.update.value.description'))
- ->addArgument(
- 'yaml-file',
- InputArgument::REQUIRED,
- $this->trans('commands.yaml.update.value.arguments.yaml-file')
- )
- ->addArgument(
- 'yaml-key',
- InputArgument::REQUIRED,
- $this->trans('commands.yaml.update.value.arguments.yaml-key')
- )
- ->addArgument(
- 'yaml-value',
- InputArgument::REQUIRED,
- $this->trans('commands.yaml.update.value.arguments.yaml-value')
- );
- }
-
- protected function execute(InputInterface $input, OutputInterface $output)
- {
- $io = new DrupalStyle($input, $output);
-
- $yaml = new Parser();
- $dumper = new Dumper();
-
- $yaml_file = $input->getArgument('yaml-file');
- $yaml_key = $input->getArgument('yaml-key');
- $yaml_value = $input->getArgument('yaml-value');
-
-
- try {
- $yaml_parsed = $yaml->parse(file_get_contents($yaml_file));
- } catch (\Exception $e) {
- $io->error($this->trans('commands.yaml.merge.messages.error-parsing').': '.$e->getMessage());
- return;
- }
-
- if (empty($yaml_parsed)) {
- $io->info(
- sprintf(
- $this->trans('commands.yaml.merge.messages.wrong-parse'),
- $yaml_file
- )
- );
- }
-
- $parents = explode(".", $yaml_key);
- $this->nestedArray->setValue($yaml_parsed, $parents, $yaml_value, true);
-
- try {
- $yaml = $dumper->dump($yaml_parsed, 10);
- } catch (\Exception $e) {
- $io->error($this->trans('commands.yaml.merge.messages.error-generating').': '.$e->getMessage());
-
- return;
- }
-
- try {
- file_put_contents($yaml_file, $yaml);
- } catch (\Exception $e) {
- $io->error($this->trans('commands.yaml.merge.messages.error-writing').': '.$e->getMessage());
-
- return;
- }
-
- $io->info(
- sprintf(
- $this->trans('commands.yaml.update.value.messages.updated'),
- $yaml_file
- )
- );
- }
-}