[ 
https://issues.apache.org/jira/browse/METRON-503?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=15874952#comment-15874952
 ] 

ASF GitHub Bot commented on METRON-503:
---------------------------------------

Github user merrimanr commented on a diff in the pull request:

    https://github.com/apache/incubator-metron/pull/316#discussion_r102076697
  
    --- Diff: 
metron-interface/metron-rest/src/main/java/org/apache/metron/rest/controller/HdfsController.java
 ---
    @@ -0,0 +1,89 @@
    +/**
    + * Licensed to the Apache Software Foundation (ASF) under one
    + * or more contributor license agreements.  See the NOTICE file
    + * distributed with this work for additional information
    + * regarding copyright ownership.  The ASF licenses this file
    + * to you 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.apache.metron.rest.controller;
    +
    +import io.swagger.annotations.ApiOperation;
    +import io.swagger.annotations.ApiParam;
    +import io.swagger.annotations.ApiResponse;
    +import io.swagger.annotations.ApiResponses;
    +import org.apache.hadoop.fs.Path;
    +import org.apache.metron.rest.RestException;
    +import org.apache.metron.rest.service.HdfsService;
    +import org.springframework.beans.factory.annotation.Autowired;
    +import org.springframework.http.HttpStatus;
    +import org.springframework.http.ResponseEntity;
    +import org.springframework.web.bind.annotation.RequestBody;
    +import org.springframework.web.bind.annotation.RequestMapping;
    +import org.springframework.web.bind.annotation.RequestMethod;
    +import org.springframework.web.bind.annotation.RequestParam;
    +import org.springframework.web.bind.annotation.RestController;
    +
    +import java.util.List;
    +
    +import static java.nio.charset.StandardCharsets.UTF_8;
    +
    +@RestController
    +@RequestMapping("/api/v1/hdfs")
    +public class HdfsController {
    +
    +  @Autowired
    +  private HdfsService hdfsService;
    +
    +  @ApiOperation(value = "Reads a file from HDFS and returns the contents")
    +  @ApiResponse(message = "Returns file contents", code = 200)
    +  @RequestMapping(value = "/list", method = RequestMethod.GET)
    +  ResponseEntity<List<String>> list(@ApiParam(name = "path", value = "Path 
to HDFS directory", required = true) @RequestParam String path) throws 
RestException {
    +    return new ResponseEntity<>(hdfsService.list(new Path(path)), 
HttpStatus.OK);
    +  }
    +
    +  @ApiOperation(value = "Reads a file from HDFS and returns the contents")
    +  @ApiResponse(message = "Returns file contents", code = 200)
    +  @RequestMapping(method = RequestMethod.GET)
    +  ResponseEntity<String> read(@ApiParam(name = "path", value = "Path to 
HDFS file", required = true) @RequestParam String path) throws RestException {
    +    String contents = hdfsService.read(new Path(path));
    +    if (contents != null) {
    +      return new ResponseEntity<>(hdfsService.read(new Path(path)), 
HttpStatus.OK);
    +    } else {
    +      return new ResponseEntity<>(HttpStatus.NOT_FOUND);
    +    }
    +
    +  }
    +
    +  @ApiOperation(value = "Writes contents to an HDFS file")
    +  @ApiResponse(message = "Contents were written", code = 200)
    +  @RequestMapping(method = RequestMethod.POST)
    +  ResponseEntity<Void> write(@ApiParam(name="path", value="Path to HDFS 
file", required=true) @RequestParam String path,
    --- End diff --
    
    Done


> Metron REST API
> ---------------
>
>                 Key: METRON-503
>                 URL: https://issues.apache.org/jira/browse/METRON-503
>             Project: Metron
>          Issue Type: New Feature
>            Reporter: Ryan Merriman
>            Assignee: Ryan Merriman
>         Attachments: Metron REST API.docx
>
>
> As discussed on the dev list ([DISCUSS] Metron REST API Requirements), this 
> Jira includes adding a REST API to Metron.



--
This message was sent by Atlassian JIRA
(v6.3.15#6346)

Reply via email to