Nano Hash - криптовалюты, майнинг, программирование

Свойства получения FOSRestBundle отличаются от свойств публикации.

У меня проблема с FOSRestBundle. Когда я запускаю действие get над коллекцией, я получаю что-то вроде этого (формат json):

{"entities":[{"id":1,"main_diagnostic_name":"0000","main_diagnostic_code":"1111","start_date":null,"end_date":null,"patient":{"id":1,"identifier":"3874908","first_name":"Pedro","surname":"Barroso","gender":"M","birth_date":"1972-01-01T00:00:00+0000","photo":null,"communication":"ab","active":true,"nhc":null,"allergy":false,"episodes":[]},"prescriptions":[],"id_bed":1,"separate":null,"special_diet":false,"contagious_diseases":false,"aggressive":false}]}

Но когда я делаю почтовый вызов для той же коллекции, мне нужно указать имена переменных:

{"mainDiagnosticName":"XXXX","mainDiagnosticCode":"1111","startDate":null,"endDate":null,"patient":"1","idBed":1,"separate":null,"specialDiet":false,"contagiousDiseases":false,"aggressive":false}

Как сделать так, чтобы оба действия имели одинаковое поведение? Почему get возвращает меня к подчеркнутым параметрам?

Это моя сущность:

<?php

namespace wathever;

use Doctrine\ORM\Mapping as ORM;

/**
 * Episode
 *
 * @ORM\Table()
 * @ORM\Entity(repositoryClass="Strim\NursingBundle\Entity\EpisodeRepository")
 */
class Episode {

/**
 * @var integer
 * @ORM\Column(name="id", type="integer")
 * @ORM\Id
 * @ORM\GeneratedValue(strategy="AUTO")
 * @ORM\OneToMany(targetEntity="Prescription" , mappedBy="id")
 */
private $id;

/**
 * @var string
 *
 * @ORM\Column(name="mainDiagnosticName", type="string", length=100)
 */
private $mainDiagnosticName;

/**
 * @var string
 *
 * @ORM\Column(name="mainDiagnosticCode", type="string", length=10)
 */
private $mainDiagnosticCode;

/**
 * @var \DateTime
 *
 * @ORM\Column(name="startDate", type="datetime", nullable=true)
 */
private $startDate;

/**
 * @var \DateTime
 *
 * @ORM\Column(name="endDate", type="datetime", nullable=true)
 */
private $endDate;

/**
 * @ORM\ManyToOne(targetEntity="Patient", inversedBy="patient")
 * @ORM\JoinColumn(name="patient_id", referencedColumnName="id")
 */
private $patient;

/**
 * @ORM\OneToMany(targetEntity="Prescription" , mappedBy="episodes")
 */
private $prescriptions;

/**
 * @var integer
 * @ORM\Column(name="idBed", type="integer", nullable=true)
 */
private $idBed;

/**
 * @var boolean
 * @ORM\ManyToOne(targetEntity="Beds")
 * @ORM\JoinColumn(name="bed_id", referencedColumnName="id") */
private $separate;

/**
 * @var boolean
 *
 * @ORM\Column(name="specialDiet", type="boolean")
 */
// TODO esto como boleano no debería ser
private $specialDiet;

/**
 * @var boolean
 *
 * @ORM\Column(name="contagiousDiseases", type="boolean")
 */
// TODO esto como boleano no debería ser
private $contagiousDiseases;

/**
 * @var boolean
 *
 * @ORM\Column(name="aggressive", type="boolean")
 */
private $aggressive;

/**
 * Get id
 *
 * @return integer 
 */
public function getId() {
    return $this->id;
}

/**
 * Set mainDiagnosticName
 *
 * @param string $mainDiagnosticName
 * @return Episode
 */
public function setMainDiagnosticName($mainDiagnosticName) {
    $this->mainDiagnosticName = $mainDiagnosticName;

    return $this;
}

/**
 * Get mainDiagnosticName
 *
 * @return string 
 */
public function getMainDiagnosticName() {
    return $this->mainDiagnosticName;
}

/**
 * Set mainDiagnosticCode
 *
 * @param string $mainDiagnosticCode
 * @return Episode
 */
public function setMainDiagnosticCode($mainDiagnosticCode) {
    $this->mainDiagnosticCode = $mainDiagnosticCode;

    return $this;
}

/**
 * Get mainDiagnosticCode
 *
 * @return string 
 */
public function getMainDiagnosticCode() {
    return $this->mainDiagnosticCode;
}

/**
 * Set startDate
 *
 * @param \DateTime $startDate
 * @return Episode
 */
public function setStartDate($startDate) {
    $this->startDate = $startDate;

    return $this;
}

/**
 * Get startDate
 *
 * @return \DateTime 
 */
public function getStartDate() {
    return $this->startDate;
}

/**
 * Set endDate
 *
 * @param \DateTime $endDate
 * @return Episode
 */
public function setEndDate($endDate) {
    $this->endDate = $endDate;

    return $this;
}

/**
 * Get endDate
 *
 * @return \DateTime 
 */
public function getEndDate() {
    return $this->endDate;
}

/**
 * Set patient
 *
 * @param integer $patient
 * @return Episode
 */
public function setIdPatient($idPatient) {
    $this->patient = $patient;

    return $this;
}

/**
 * Get patient
 *
 * @return integer 
 */
public function getPatient() {
    return $this->patient;
}

/**
 * Set idBed
 *
 * @param integer $idBed
 * @return Episode
 */
public function setIdBed($idBed) {
    $this->idBed = $idBed;

    return $this;
}

/**
 * Get idBed
 *
 * @return integer 
 */
public function getIdBed() {
    return $this->idBed;
}

/**
 * Set separate
 *
 * @param boolean $separate
 * @return Episode
 */
public function setSeparate($separate) {
    $this->separate = $separate;

    return $this;
}

/**
 * Get separate
 *
 * @return boolean 
 */
public function getSeparate() {
    return $this->separate;
}

/**
 * Set specialDiet
 *
 * @param boolean $specialDiet
 * @return Episode
 */
public function setSpecialDiet($specialDiet) {
    $this->specialDiet = $specialDiet;

    return $this;
}

/**
 * Get specialDiet
 *
 * @return boolean 
 */
public function getSpecialDiet() {
    return $this->specialDiet;
}

/**
 * Set contagiousDiseases
 *
 * @param boolean $contagiousDiseases
 * @return Episode
 */
public function setContagiousDiseases($contagiousDiseases) {
    $this->contagiousDiseases = $contagiousDiseases;

    return $this;
}

/**
 * Get contagiousDiseases
 *
 * @return boolean 
 */
public function getContagiousDiseases() {
    return $this->contagiousDiseases;
}

/**
 * Set aggressive
 *
 * @param boolean $aggressive
 * @return Episode
 */
public function setAggressive($aggressive) {
    $this->aggressive = $aggressive;

    return $this;
}

/**
 * Get aggressive
 *
 * @return boolean 
 */
public function getAggressive() {
    return $this->aggressive;
}

/**
 * Set patient
 *
 * @param \Strim\NursingBundle\Entity\Patient $patient
 * @return Episode
 */
public function setPatient(\Strim\NursingBundle\Entity\Patient $patient = null) {
    $this->patient = $patient;

    return $this;
}

/**
 * Constructor
 */
public function __construct($object = null) {
    $this->prescriptions = new \Doctrine\Common\Collections\ArrayCollection();
    $this->patient = new \Doctrine\Common\Collections\ArrayCollection();
    if ($object){
        $this->setParameters($object);
    }
}

public function setParameters($object){

    $vars = get_object_vars($object)
            ;
            foreach ($vars as $v){

call_user_func('set'.$v, $object->get($v));
            }

    return $this;
}


 /**
 * Add prescriptions
 *
 * @param \Strim\NursingBundle\Entity\Prescription $prescriptions
 * @return Episode
 */
public function addPrescription(\Strim\NursingBundle\Entity\Prescription $prescriptions) {
    $this->prescriptions[] = $prescriptions;

    return $this;
}

/**
 * Remove prescriptions
 *
 * @param \Strim\NursingBundle\Entity\Prescription $prescriptions
 */
public function removePrescription(\Strim\NursingBundle\Entity\Prescription $prescriptions) {
    $this->prescriptions->removeElement($prescriptions);
}

/**
 * Get prescriptions
 *
 * @return \Doctrine\Common\Collections\Collection 
 */
public function getPrescriptions() {
    return $this->prescriptions;
}

}

Это мой cgetAction:

/**
 * Collection get action
 * @var Request $request
 * @return array
 * @Rest\View()
 */
public function cgetAction(Request $request) {
    $em = $this->getDoctrine()->getManager();
    $entities = $em->getRepository('MyBundle:Episode')->findAll();
    return array(
        'entities' => $entities,
    );
}

И мое действие POST:

/**
 * Collection post action -> Crear un elemento de la colección
 * @var Request $request
 * @return View|array
 * @Rest\View()
 */
public function cpostAction(Request $request) {
      $entity = new Episode();
      $form = $this->createForm(new EpisodeType(), $entity);

      $form->bind($request);
 if ($form->isValid()) {
        $em = $this->getDoctrine()->getManager();
        $em->persist($entity);
        $em->flush();

        return new Response($request, 201);
    }

    return array(
        'form' => $form,
    );
}
23.09.2013

  • Никто не знает? Я видел это в JMSSerializerBundle, но я ищу лучшее решение: @SerializedName¶ Эту аннотацию можно определить для свойства, чтобы определить сериализованное имя свойства. Если это не определено, свойство будет переведено из верблюжьего регистра в имя с подчеркиванием в нижнем регистре, например. верблюжий регистр -> верблюжий_кейс. 24.09.2013
  • См. эту ссылку: github.com/schmittjoh/serializer/issues/33, однако это не совсем ясно, как реализовать этот проход через стратегию именования как часть FOSRest. Я изучаю это в данный момент, потому что да, это боль 05.12.2013

Ответы:


1

Чтобы иметь тот же формат json, что и действие «post», вы должны использовать FOSRestBundle View:

вот выдержка о том, как должен выглядеть ваш cgetAction:

/**
* Collection get action
* @var Request $request
* @return array
* @Rest\View()
*/
public function cgetAction(Request $request) {
   $em = $this->getDoctrine()->getManager();
   $entities = $em->getRepository('MyBundle:Episode')->findAll();

   //set the view:
   $view = View::create();
   $handler = $this->get('fos_rest.view_handler');
   $view->setData($entity);

   return $view;
 }

Не забудьте добавить в оператор «use» use FOS\RestBundle\View\View;, чтобы иметь возможность использовать обработчик представления FosRestBungle.

13.12.2013

2

Редактировать: Только после отправки этого сообщения я заметил, что для моего варианта использования будет намного проще просто использовать IdenticalPropertyNamingStrategy, поставляемый с JMSSerializer, вместо метода переопределения и деконфигурации, описанного ниже. То, что остается, таким образом, просто

# file: app/config.yml
parameters:
    jms_serializer.camel_case_naming_strategy.class: JMS\Serializer\Naming\IdenticalPropertyNamingStrategy

Это может помочь вам переопределить стратегию именования верблюжьих регистров JMSSerializer по умолчанию. Я расширил CamelCaseNamingStrategy следующим образом.

// File: MyName/MyBundle/Serializer/CamelCaseNamingStrategy.php
namespace MyName\MyBundle\Serializer;
use JMS\Serializer\Metadata\PropertyMetadata;

class CamelCaseNamingStrategy extends \JMS\Serializer\Naming\CamelCaseNamingStrategy
{
    public function translateName(PropertyMetadata $property)
    {
        return lcfirst(parent::translateName($property));
    }
}

Затем вы можете настроить JMSSerializerBundle для использования этого класса вместо исходного.

# file: app/config.yml
parameters:
    jms_serializer.camel_case_naming_strategy.class: MyName\MyBundle\Serializer\CamelCaseNamingStrategy

Наконец, вам нужно отключить вставку нижнего регистра и разделителя, которую обычно делает JMSSerializer.

# still in app/config.yml
jms_serializer:
    property_naming:
        separator:
        lower_case: false
30.12.2013
  • Приятно ! Я не очень понимаю, почему имена свойств подчеркнуты и поэтому не оставлены как есть по умолчанию 04.02.2015
  • На самом деле это не проще, потому что IdenticalPropertyNamingStrategy не учитывает ваши типы конфигурации и прочее. 28.11.2015
  • Новые материалы

    Кластеризация: более глубокий взгляд
    Кластеризация — это метод обучения без учителя, в котором мы пытаемся найти группы в наборе данных на основе некоторых известных или неизвестных свойств, которые могут существовать. Независимо от..

    Как написать эффективное резюме
    Предложения по дизайну и макету, чтобы представить себя профессионально Вам не позвонили на собеседование после того, как вы несколько раз подали заявку на работу своей мечты? У вас может..

    Частный метод Python: улучшение инкапсуляции и безопасности
    Введение Python — универсальный и мощный язык программирования, известный своей простотой и удобством использования. Одной из ключевых особенностей, отличающих Python от других языков, является..

    Как я автоматизирую тестирование с помощью Jest
    Шутка для победы, когда дело касается автоматизации тестирования Одной очень важной частью разработки программного обеспечения является автоматизация тестирования, поскольку она создает..

    Работа с векторными символическими архитектурами, часть 4 (искусственный интеллект)
    Hyperseed: неконтролируемое обучение с векторными символическими архитектурами (arXiv) Автор: Евгений Осипов , Сачин Кахавала , Диланта Хапутантри , Тимал Кемпития , Дасвин Де Сильва ,..

    Понимание расстояния Вассерштейна: мощная метрика в машинном обучении
    В обширной области машинного обучения часто возникает необходимость сравнивать и измерять различия между распределениями вероятностей. Традиционные метрики расстояния, такие как евклидово..

    Обеспечение масштабируемости LLM: облачный анализ с помощью AWS Fargate и Copilot
    В динамичной области искусственного интеллекта все большее распространение получают модели больших языков (LLM). Они жизненно важны для различных приложений, таких как интеллектуальные..