Uploaded image for project: 'Zeppelin'
  1. Zeppelin
  2. ZEPPELIN-2713

notebook create rest api works bad when no message is supplied

    XMLWordPrintableJSON

Details

    • Bug
    • Status: Resolved
    • Major
    • Resolution: Fixed
    • 0.7.2
    • 0.8.0
    • zeppelin-server
    • None

    Description

      When post api/notebook rest uri without any message supplied, there will be a NPE because request is null, but the dirty notebook has already been created before this exception.
      See the original code:

      @POST
      @Path("/")
      @ZeppelinApi
      public Response createNote(String message) throws IOException {
      String user = SecurityUtils.getPrincipal();
      LOG.info("Create new note by JSON {}", message);
      NewNoteRequest request = gson.fromJson(message, NewNoteRequest.class);
      AuthenticationInfo subject = new AuthenticationInfo(user);
      Note note = notebook.createNote(subject);
      List<NewParagraphRequest> initialParagraphs = request.getParagraphs();
      if (initialParagraphs != null) {
      for (NewParagraphRequest paragraphRequest : initialParagraphs)

      { Paragraph p = note.addNewParagraph(subject); initParagraph(p, paragraphRequest, user); }

      }

      If message is null, the request is null, but the notebook.createNote() is already called.
      So this exception comes out:

      Caused by: java.lang.NullPointerException
      at org.apache.zeppelin.rest.NotebookRestApi.createNote(NotebookRestApi.java:343)
      at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
      at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
      at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
      at java.lang.reflect.Method.invoke(Method.java:606)
      at org.glassfish.jersey.server.model.internal.ResourceMethodInvocationHandlerFactory$1.invoke(ResourceMethodInvocationHandlerFactory.java:81)
      at org.glassfish.jersey.server.model.internal.AbstractJavaResourceMethodDispatcher$1.run(AbstractJavaResourceMethodDispatcher.java:144)
      at org.glassfish.jersey.server.model.internal.AbstractJavaResourceMethodDispatcher.invoke(AbstractJavaResourceMethodDispatcher.java:161)
      at org.glassfish.jersey.server.model.internal.JavaResourceMethodDispatcherProvider$ResponseOutInvoker.doDispatch(JavaResourceMethodDispatcherProvider.java:160)
      at org.glassfish.jersey.server.model.internal.AbstractJavaResourceMethodDispatcher.dispatch(AbstractJavaResourceMethodDispatcher.java:99)
      at org.glassfish.jersey.server.model.ResourceMethodInvoker.invoke(ResourceMethodInvoker.java:389)
      at org.glassfish.jersey.server.model.ResourceMethodInvoker.apply(ResourceMethodInvoker.java:347)
      at org.glassfish.jersey.server.model.ResourceMethodInvoker.apply(ResourceMethodInvoker.java:102)
      at org.glassfish.jersey.server.ServerRuntime$2.run(ServerRuntime.java:326)
      at org.glassfish.jersey.internal.Errors$1.call(Errors.java:271)
      at org.glassfish.jersey.internal.Errors$1.call(Errors.java:267)
      at org.glassfish.jersey.internal.Errors.process(Errors.java:315)
      at org.glassfish.jersey.internal.Errors.process(Errors.java:297)
      at org.glassfish.jersey.internal.Errors.process(Errors.java:267)
      at org.glassfish.jersey.process.internal.RequestScope.runInScope(RequestScope.java:317)
      at org.glassfish.jersey.server.ServerRuntime.process(ServerRuntime.java:305)
      at org.glassfish.jersey.server.ApplicationHandler.handle(ApplicationHandler.java:1154)
      at org.glassfish.jersey.servlet.WebComponent.serviceImpl(WebComponent.java:473)

      Attachments

        Issue Links

          Activity

            People

              sleefd slee
              sleefd slee
              Votes:
              0 Vote for this issue
              Watchers:
              3 Start watching this issue

              Dates

                Created:
                Updated:
                Resolved: