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}