001/* 002 * Copyright (c) 2012 Nuxeo SA (http://nuxeo.com/) and others. 003 * 004 * All rights reserved. This program and the accompanying materials 005 * are made available under the terms of the Eclipse Public License v1.0 006 * which accompanies this distribution, and is available at 007 * http://www.eclipse.org/legal/epl-v10.html 008 * 009 * Contributors: 010 * Olivier Grisel <ogrisel@nuxeo.com> 011 */ 012package org.nuxeo.ecm.automation.core.impl.adapters; 013 014import java.util.List; 015 016import org.codehaus.jackson.map.ObjectMapper; 017import org.nuxeo.ecm.automation.OperationContext; 018import org.nuxeo.ecm.automation.TypeAdaptException; 019import org.nuxeo.ecm.automation.TypeAdapter; 020 021/** 022 * Make it possible to directly JSON tree nodes parsed by the REST API (e.g. parameters or input) directly to java 023 * datastructures. 024 * 025 * @author Olivier Grisel 026 * @since 5.7 027 */ 028public class ArrayNodeToList implements TypeAdapter { 029 030 ObjectMapper mapper = new ObjectMapper(); 031 032 @Override 033 public Object getAdaptedValue(OperationContext ctx, Object objectToAdapt) throws TypeAdaptException { 034 return mapper.convertValue(objectToAdapt, List.class); 035 } 036 037}