All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.graphaware.module.algo.path.NumberOfShortestPathsFinderApi Maven / Gradle / Ivy

Go to download

GraphAware Framework Module exposing custom graph algorithms as Java and REST APIs

There is a newer version: 3.0.4.43.5
Show newest version
/*
 * Copyright (c) 2013-2016 GraphAware
 *
 * This file is part of the GraphAware Framework.
 *
 * GraphAware Framework is free software: you can redistribute it and/or modify it under the terms of
 * the GNU General Public License as published by the Free Software Foundation, either
 * version 3 of the License, or (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
 * without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
 * See the GNU General Public License for more details. You should have received a copy of
 * the GNU General Public License along with this program.  If not, see
 * .
 */

package com.graphaware.module.algo.path;

import org.neo4j.graphdb.GraphDatabaseService;
import org.neo4j.graphdb.NotFoundException;
import org.neo4j.graphdb.Path;
import org.neo4j.graphdb.Transaction;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.http.HttpStatus;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.*;

import java.util.LinkedList;
import java.util.List;

/**
 * REST API for {@link com.graphaware.module.algo.path.NumberOfShortestPathsFinder}.
 */
@Controller
@RequestMapping("/algorithm/path")
public class NumberOfShortestPathsFinderApi {

    private final GraphDatabaseService database;

    private NumberOfShortestPathsFinder pathFinder = new NumberOfShortestPathsFinder();

    @Autowired
    public NumberOfShortestPathsFinderApi(GraphDatabaseService database) {
        this.database = database;
    }

    @RequestMapping(value = "increasinglyLongerShortestPath", method = RequestMethod.POST)
    @ResponseBody
    public List numberOfShortestPaths(@RequestBody JsonPathFinderInput jsonInput) {
            List result = new LinkedList<>();

            try (Transaction tx = database.beginTx()) {
                for (Path path : pathFinder.findPaths(jsonInput.produceInput(database))) {
                    result.add(new JsonPath(path, jsonInput));
                }
                tx.success();
            }

            return result;
        }

    @ExceptionHandler(IllegalArgumentException.class)
    @ResponseStatus(HttpStatus.BAD_REQUEST)
    public void handleIllegalArguments() {
    }

    @ExceptionHandler(NotFoundException.class)
    @ResponseStatus(HttpStatus.NOT_FOUND)
    public void handleNotFound() {
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy