org.openbaton.nfvo.api.RestVirtualNetworkFunctionDescriptor.java Source code

Java tutorial

Introduction

Here is the source code for org.openbaton.nfvo.api.RestVirtualNetworkFunctionDescriptor.java

Source

/*
 * Copyright (c) 2015 Fraunhofer FOKUS
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package org.openbaton.nfvo.api;

import org.openbaton.catalogue.mano.descriptor.VirtualNetworkFunctionDescriptor;
import org.openbaton.nfvo.core.interfaces.VirtualNetworkFunctionManagement;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.http.HttpStatus;
import org.springframework.http.MediaType;
import org.springframework.web.bind.annotation.*;

import javax.validation.Valid;
import java.util.List;

@RestController
@RequestMapping("/api/v1/vnf-descriptors")
public class RestVirtualNetworkFunctionDescriptor {

    //   TODO add log prints
    //   private Logger log = LoggerFactory.getLogger(this.getClass());

    @Autowired
    private VirtualNetworkFunctionManagement vnfdManagement;

    /**
     * Adds a new VNF software Image to the image repository
     *
     * @param virtualNetworkFunctionDescriptor : VirtualNetworkFunctionDescriptor to add
     * @return VirtualNetworkFunctionDescriptor: The VirtualNetworkFunctionDescriptor filled with
     * values from the core
     */
    @RequestMapping(method = RequestMethod.POST, consumes = MediaType.APPLICATION_JSON_VALUE, produces = MediaType.APPLICATION_JSON_VALUE)
    @ResponseStatus(HttpStatus.CREATED)
    public VirtualNetworkFunctionDescriptor create(
            @RequestBody @Valid VirtualNetworkFunctionDescriptor virtualNetworkFunctionDescriptor,
            @RequestHeader(value = "project-id") String projectId) {
        return vnfdManagement.add(virtualNetworkFunctionDescriptor, projectId);
    }

    /**
     * Removes the VNF software virtualNetworkFunctionDescriptor from the
     * virtualNetworkFunctionDescriptor repository
     *
     * @param id : The virtualNetworkFunctionDescriptor's id to be deleted
     */
    @RequestMapping(value = "{id}", method = RequestMethod.DELETE)
    @ResponseStatus(HttpStatus.NO_CONTENT)
    public void delete(@PathVariable("id") String id, @RequestHeader(value = "project-id") String projectId) {

        vnfdManagement.delete(id, projectId);
    }

    /**
     * Removes multiple VirtualNetworkFunctionDescriptor from the VirtualNetworkFunctionDescriptors
     * repository
     *
     * @param ids
     */
    @RequestMapping(value = "/multipledelete", method = RequestMethod.POST, consumes = MediaType.APPLICATION_JSON_VALUE)
    @ResponseStatus(HttpStatus.NO_CONTENT)
    public void multipleDelete(@RequestBody @Valid List<String> ids,
            @RequestHeader(value = "project-id") String projectId) {
        for (String id : ids)
            vnfdManagement.delete(id, projectId);
    }

    /**
     * Returns the list of the VNF software virtualNetworkFunctionDescriptors available
     *
     * @return List<virtualNetworkFunctionDescriptor>: The list of VNF software
     * virtualNetworkFunctionDescriptors available
     */
    @RequestMapping(method = RequestMethod.GET)
    public Iterable<VirtualNetworkFunctionDescriptor> findAll(
            @RequestHeader(value = "project-id") String projectId) {
        return vnfdManagement.queryByProjectId(projectId);
    }

    /**
     * Returns the VNF software virtualNetworkFunctionDescriptor selected by id
     *
     * @param id : The id of the VNF software virtualNetworkFunctionDescriptor
     * @return virtualNetworkFunctionDescriptor: The VNF software virtualNetworkFunctionDescriptor
     * selected
     */
    @RequestMapping(value = "{id}", method = RequestMethod.GET)
    public VirtualNetworkFunctionDescriptor findById(@PathVariable("id") String id,
            @RequestHeader(value = "project-id") String projectId) {

        return vnfdManagement.query(id, projectId);
    }

    /**
     * Updates the VNF software virtualNetworkFunctionDescriptor
     *
     * @param virtualNetworkFunctionDescriptor : the VNF software virtualNetworkFunctionDescriptor to
     * be updated
     * @param id : the id of VNF software virtualNetworkFunctionDescriptor
     * @return networkServiceDescriptor: the VNF software virtualNetworkFunctionDescriptor updated
     */
    @RequestMapping(value = "{id}", method = RequestMethod.PUT, consumes = MediaType.APPLICATION_JSON_VALUE, produces = MediaType.APPLICATION_JSON_VALUE)
    @ResponseStatus(HttpStatus.ACCEPTED)
    public VirtualNetworkFunctionDescriptor update(
            @RequestBody @Valid VirtualNetworkFunctionDescriptor virtualNetworkFunctionDescriptor,
            @PathVariable("id") String id, @RequestHeader(value = "project-id") String projectId) {
        return vnfdManagement.update(virtualNetworkFunctionDescriptor, id, projectId);
    }
}