How to redirect a page after an event occurs in NodeJs












0















In my NodeJs application I want to render a file when a socket IO event occurs.



I am running a distinct socket.io server with python which does some calculation when an event occurs and triggers another return event to NodeJs side. However, redirect operation completes before the return event and page renders without the new data. What I actually want is to apply redirect with the new data 'x' after return event completes.



let x = 

app.get("/", function(req, res) {
res.render('home', {'x' : x});
});

app.post("/", function(req, res) {
socket.emit('main event', 'data'); //trigger the main event
res.redirect("/");
})

socket.on('return event', (data) => { //this is the return event
x = data.x;
// I want render to happen after this line
});


Is there any way that I can do the render operation not in express events and maybe in socket.io callback or maybe a blocking call that waits the event to complete?










share|improve this question


















  • 1





    Hi, you can for exemple execute a promise in your main action, and only render the view after it's complete....

    – Pimento Web
    Jan 1 at 22:15
















0















In my NodeJs application I want to render a file when a socket IO event occurs.



I am running a distinct socket.io server with python which does some calculation when an event occurs and triggers another return event to NodeJs side. However, redirect operation completes before the return event and page renders without the new data. What I actually want is to apply redirect with the new data 'x' after return event completes.



let x = 

app.get("/", function(req, res) {
res.render('home', {'x' : x});
});

app.post("/", function(req, res) {
socket.emit('main event', 'data'); //trigger the main event
res.redirect("/");
})

socket.on('return event', (data) => { //this is the return event
x = data.x;
// I want render to happen after this line
});


Is there any way that I can do the render operation not in express events and maybe in socket.io callback or maybe a blocking call that waits the event to complete?










share|improve this question


















  • 1





    Hi, you can for exemple execute a promise in your main action, and only render the view after it's complete....

    – Pimento Web
    Jan 1 at 22:15














0












0








0








In my NodeJs application I want to render a file when a socket IO event occurs.



I am running a distinct socket.io server with python which does some calculation when an event occurs and triggers another return event to NodeJs side. However, redirect operation completes before the return event and page renders without the new data. What I actually want is to apply redirect with the new data 'x' after return event completes.



let x = 

app.get("/", function(req, res) {
res.render('home', {'x' : x});
});

app.post("/", function(req, res) {
socket.emit('main event', 'data'); //trigger the main event
res.redirect("/");
})

socket.on('return event', (data) => { //this is the return event
x = data.x;
// I want render to happen after this line
});


Is there any way that I can do the render operation not in express events and maybe in socket.io callback or maybe a blocking call that waits the event to complete?










share|improve this question














In my NodeJs application I want to render a file when a socket IO event occurs.



I am running a distinct socket.io server with python which does some calculation when an event occurs and triggers another return event to NodeJs side. However, redirect operation completes before the return event and page renders without the new data. What I actually want is to apply redirect with the new data 'x' after return event completes.



let x = 

app.get("/", function(req, res) {
res.render('home', {'x' : x});
});

app.post("/", function(req, res) {
socket.emit('main event', 'data'); //trigger the main event
res.redirect("/");
})

socket.on('return event', (data) => { //this is the return event
x = data.x;
// I want render to happen after this line
});


Is there any way that I can do the render operation not in express events and maybe in socket.io callback or maybe a blocking call that waits the event to complete?







node.js express socket.io ejs






share|improve this question













share|improve this question











share|improve this question




share|improve this question










asked Jan 1 at 21:14









barkın evginbarkın evgin

715




715








  • 1





    Hi, you can for exemple execute a promise in your main action, and only render the view after it's complete....

    – Pimento Web
    Jan 1 at 22:15














  • 1





    Hi, you can for exemple execute a promise in your main action, and only render the view after it's complete....

    – Pimento Web
    Jan 1 at 22:15








1




1





Hi, you can for exemple execute a promise in your main action, and only render the view after it's complete....

– Pimento Web
Jan 1 at 22:15





Hi, you can for exemple execute a promise in your main action, and only render the view after it's complete....

– Pimento Web
Jan 1 at 22:15












2 Answers
2






active

oldest

votes


















0














Add res.redirect to acknowledgment callback in socket.emit.



app.post("/", function(req, res) {
socket.emit('main event', 'data', function(err, msg) {
if(err) throw new Error(err);

res.redirect("/");
});
});





share|improve this answer































    0














    Thank you for all your answers. What I actually needed was to put the socket.on event into the app.post like this.



    app.post("/", function(req, res) {
    socket.on('return event', (data) => {
    x = data.x;
    res.redirect("/");
    });
    socket.emit('main event', 'data');
    })


    Promises was also a good suggestion and thank you for all your answers again






    share|improve this answer























      Your Answer






      StackExchange.ifUsing("editor", function () {
      StackExchange.using("externalEditor", function () {
      StackExchange.using("snippets", function () {
      StackExchange.snippets.init();
      });
      });
      }, "code-snippets");

      StackExchange.ready(function() {
      var channelOptions = {
      tags: "".split(" "),
      id: "1"
      };
      initTagRenderer("".split(" "), "".split(" "), channelOptions);

      StackExchange.using("externalEditor", function() {
      // Have to fire editor after snippets, if snippets enabled
      if (StackExchange.settings.snippets.snippetsEnabled) {
      StackExchange.using("snippets", function() {
      createEditor();
      });
      }
      else {
      createEditor();
      }
      });

      function createEditor() {
      StackExchange.prepareEditor({
      heartbeatType: 'answer',
      autoActivateHeartbeat: false,
      convertImagesToLinks: true,
      noModals: true,
      showLowRepImageUploadWarning: true,
      reputationToPostImages: 10,
      bindNavPrevention: true,
      postfix: "",
      imageUploader: {
      brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
      contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
      allowUrls: true
      },
      onDemand: true,
      discardSelector: ".discard-answer"
      ,immediatelyShowMarkdownHelp:true
      });


      }
      });














      draft saved

      draft discarded


















      StackExchange.ready(
      function () {
      StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53998992%2fhow-to-redirect-a-page-after-an-event-occurs-in-nodejs%23new-answer', 'question_page');
      }
      );

      Post as a guest















      Required, but never shown

























      2 Answers
      2






      active

      oldest

      votes








      2 Answers
      2






      active

      oldest

      votes









      active

      oldest

      votes






      active

      oldest

      votes









      0














      Add res.redirect to acknowledgment callback in socket.emit.



      app.post("/", function(req, res) {
      socket.emit('main event', 'data', function(err, msg) {
      if(err) throw new Error(err);

      res.redirect("/");
      });
      });





      share|improve this answer




























        0














        Add res.redirect to acknowledgment callback in socket.emit.



        app.post("/", function(req, res) {
        socket.emit('main event', 'data', function(err, msg) {
        if(err) throw new Error(err);

        res.redirect("/");
        });
        });





        share|improve this answer


























          0












          0








          0







          Add res.redirect to acknowledgment callback in socket.emit.



          app.post("/", function(req, res) {
          socket.emit('main event', 'data', function(err, msg) {
          if(err) throw new Error(err);

          res.redirect("/");
          });
          });





          share|improve this answer













          Add res.redirect to acknowledgment callback in socket.emit.



          app.post("/", function(req, res) {
          socket.emit('main event', 'data', function(err, msg) {
          if(err) throw new Error(err);

          res.redirect("/");
          });
          });






          share|improve this answer












          share|improve this answer



          share|improve this answer










          answered Jan 2 at 5:45









          Rajika ImalRajika Imal

          163312




          163312

























              0














              Thank you for all your answers. What I actually needed was to put the socket.on event into the app.post like this.



              app.post("/", function(req, res) {
              socket.on('return event', (data) => {
              x = data.x;
              res.redirect("/");
              });
              socket.emit('main event', 'data');
              })


              Promises was also a good suggestion and thank you for all your answers again






              share|improve this answer




























                0














                Thank you for all your answers. What I actually needed was to put the socket.on event into the app.post like this.



                app.post("/", function(req, res) {
                socket.on('return event', (data) => {
                x = data.x;
                res.redirect("/");
                });
                socket.emit('main event', 'data');
                })


                Promises was also a good suggestion and thank you for all your answers again






                share|improve this answer


























                  0












                  0








                  0







                  Thank you for all your answers. What I actually needed was to put the socket.on event into the app.post like this.



                  app.post("/", function(req, res) {
                  socket.on('return event', (data) => {
                  x = data.x;
                  res.redirect("/");
                  });
                  socket.emit('main event', 'data');
                  })


                  Promises was also a good suggestion and thank you for all your answers again






                  share|improve this answer













                  Thank you for all your answers. What I actually needed was to put the socket.on event into the app.post like this.



                  app.post("/", function(req, res) {
                  socket.on('return event', (data) => {
                  x = data.x;
                  res.redirect("/");
                  });
                  socket.emit('main event', 'data');
                  })


                  Promises was also a good suggestion and thank you for all your answers again







                  share|improve this answer












                  share|improve this answer



                  share|improve this answer










                  answered Jan 2 at 15:58









                  barkın evginbarkın evgin

                  715




                  715






























                      draft saved

                      draft discarded




















































                      Thanks for contributing an answer to Stack Overflow!


                      • Please be sure to answer the question. Provide details and share your research!

                      But avoid



                      • Asking for help, clarification, or responding to other answers.

                      • Making statements based on opinion; back them up with references or personal experience.


                      To learn more, see our tips on writing great answers.




                      draft saved


                      draft discarded














                      StackExchange.ready(
                      function () {
                      StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53998992%2fhow-to-redirect-a-page-after-an-event-occurs-in-nodejs%23new-answer', 'question_page');
                      }
                      );

                      Post as a guest















                      Required, but never shown





















































                      Required, but never shown














                      Required, but never shown












                      Required, but never shown







                      Required, but never shown

































                      Required, but never shown














                      Required, but never shown












                      Required, but never shown







                      Required, but never shown







                      Popular posts from this blog

                      android studio warns about leanback feature tag usage required on manifest while using Unity exported app?

                      SQL update select statement

                      'app-layout' is not a known element: how to share Component with different Modules