--- /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
+ )
+ );
+ }
+}