2017 © Pedro Peláez
 

library http-serializer

Serializes a Controller Request & Response

image

geosocio/http-serializer

Serializes a Controller Request & Response

  • Sunday, March 18, 2018
  • by davidbarratt
  • Repository
  • 1 Watchers
  • 2 Stars
  • 219 Installations
  • PHP
  • 1 Dependents
  • 0 Suggesters
  • 1 Forks
  • 0 Open issues
  • 20 Versions
  • 26 % Grown

The README.md

Http Serializer Build Status Coverage Status

Serializes a Controller Request & Response., (*1)

Request

POST & PUT requests may have their contents deserialized into an object. Any request with a content body (e.g. PATCH) may have the contents decoded into an array., (*2)

Response

A controller's response will serialized into the same format of the request. If you need more advanced handling, you may always return a Response object without interference., (*3)

Groups

Groups may be applied to the request or the response (or both) with the groups annotation. * Request Groups GeoSocio\HttpSerializer\Annotation\RequestGroups * Response Groups GeoSocio\HttpSerializer\Annotation\ResponseGroups * Request & Response Groups Symfony\Component\Serializer\Annotation\Groups, (*4)

They may also be applied with a GroupResolver., (*5)

Example

/**
 * @Route("/post/{post}")
 * @Method({"GET"})
 *
 * @Groups({"show"})
 */
public function showAction(Post $post) {
    return $post;
}

/**
 * @Route("/post")
 * @Method({"POST"})
 *
 * @RequestGroups({"create"})
 * @ResponseGroups({"show"})
 */
public function createAction(Post $post) {
    $em = $this->doctrine->getEntityManager();
    $em->persist($post);
    $em->flush();
    return $post;
}

/**
 * @Route("/post/{post}")
 * @Method({"PUT"})
 *
 * @RequestGroups({"replace"})
 * @ResponseGroups({"show"})
 */
public function replaceAction(Post $post, Post $content) {
    $em = $this->doctrine->getEntityManager();
    $em->merge($content);
    $em->flush();
    return $post;
}

/**
 * @Route("/post/{post}")
 * @Method({"PATCH"})
 *
 * @RequestGroups({"update"})
 * @ResponseGroups({"show"})
 */
public function updateAction(Post $post, array $content) {
    $em = $this->doctrine->getEntityManager();
    $post = $this->serializer->denormalizer($content, $post);
    $em->flush();
    return $post;
}

/**
 * @Route("/post/{post}")
 * @Method({"DELETE"})
 */
public function deleteAction(Post $post) {
    $em = $this->doctrine->getEntityManager();
    $em->remove($post);
    $em->flush();
    return '';
}

The Versions

18/03 2018