Expo push notifications stopped working in production











up vote
0
down vote

favorite












I'm using Expo to develop both Android and iOS at same time. Notifications were working fine for several weeks, and then out of no where stopped working in production, even though I did not update the app during this time.



Server-side, everything is still fine, and notifications are being pushed. In dev, notifications are still being received and handled properly, but in production, it's crickets.



Has anyone else experienced this / what could be causing this?



Here is my code:



class Dashboard extends Component {

constructor(props) {
super(props);
this.state = {
notificationsSet: false,
}

}

componentDidMount() {
this.registerForPushNotificationsAsync(this.props.currentUser.currentUser.id, this.props.currentUser.authToken)

savePushToken = (userId, pushToken, token) => {
//API call to save push token to database
apiHelper
.savePushToken(userId, pushToken, token)
.then(res => {
return
})
.catch(err => console.log("err saving", err));
};

handleNotification = notification => {
this.props.setNotification({ notification })
}

registerForPushNotificationsAsync = async (userId, token) =>{
//requesting if user would like to turn on notifications
const { status: existingStatus } = await Permissions.getAsync(
Permissions.NOTIFICATIONS
);
//this checks if notifications is turned on for the app --- "granted"
let finalStatus = existingStatus;
if (existingStatus !== "granted") {
const { status } = await Permissions.askAsync(Permissions.NOTIFICATIONS);

finalStatus = status;
}
if (finalStatus !== "granted") {
return;
} //if "granted" then get push notifications and calls this.savepushtoken to save into the API

let pushToken = await Notifications.getExpoPushTokenAsync();

this.subscription = Notifications.addListener(this.handleNotification);
this.savePushToken(userId, pushToken, token);
};

render() {
return(...)
}
}









share|improve this question


























    up vote
    0
    down vote

    favorite












    I'm using Expo to develop both Android and iOS at same time. Notifications were working fine for several weeks, and then out of no where stopped working in production, even though I did not update the app during this time.



    Server-side, everything is still fine, and notifications are being pushed. In dev, notifications are still being received and handled properly, but in production, it's crickets.



    Has anyone else experienced this / what could be causing this?



    Here is my code:



    class Dashboard extends Component {

    constructor(props) {
    super(props);
    this.state = {
    notificationsSet: false,
    }

    }

    componentDidMount() {
    this.registerForPushNotificationsAsync(this.props.currentUser.currentUser.id, this.props.currentUser.authToken)

    savePushToken = (userId, pushToken, token) => {
    //API call to save push token to database
    apiHelper
    .savePushToken(userId, pushToken, token)
    .then(res => {
    return
    })
    .catch(err => console.log("err saving", err));
    };

    handleNotification = notification => {
    this.props.setNotification({ notification })
    }

    registerForPushNotificationsAsync = async (userId, token) =>{
    //requesting if user would like to turn on notifications
    const { status: existingStatus } = await Permissions.getAsync(
    Permissions.NOTIFICATIONS
    );
    //this checks if notifications is turned on for the app --- "granted"
    let finalStatus = existingStatus;
    if (existingStatus !== "granted") {
    const { status } = await Permissions.askAsync(Permissions.NOTIFICATIONS);

    finalStatus = status;
    }
    if (finalStatus !== "granted") {
    return;
    } //if "granted" then get push notifications and calls this.savepushtoken to save into the API

    let pushToken = await Notifications.getExpoPushTokenAsync();

    this.subscription = Notifications.addListener(this.handleNotification);
    this.savePushToken(userId, pushToken, token);
    };

    render() {
    return(...)
    }
    }









    share|improve this question
























      up vote
      0
      down vote

      favorite









      up vote
      0
      down vote

      favorite











      I'm using Expo to develop both Android and iOS at same time. Notifications were working fine for several weeks, and then out of no where stopped working in production, even though I did not update the app during this time.



      Server-side, everything is still fine, and notifications are being pushed. In dev, notifications are still being received and handled properly, but in production, it's crickets.



      Has anyone else experienced this / what could be causing this?



      Here is my code:



      class Dashboard extends Component {

      constructor(props) {
      super(props);
      this.state = {
      notificationsSet: false,
      }

      }

      componentDidMount() {
      this.registerForPushNotificationsAsync(this.props.currentUser.currentUser.id, this.props.currentUser.authToken)

      savePushToken = (userId, pushToken, token) => {
      //API call to save push token to database
      apiHelper
      .savePushToken(userId, pushToken, token)
      .then(res => {
      return
      })
      .catch(err => console.log("err saving", err));
      };

      handleNotification = notification => {
      this.props.setNotification({ notification })
      }

      registerForPushNotificationsAsync = async (userId, token) =>{
      //requesting if user would like to turn on notifications
      const { status: existingStatus } = await Permissions.getAsync(
      Permissions.NOTIFICATIONS
      );
      //this checks if notifications is turned on for the app --- "granted"
      let finalStatus = existingStatus;
      if (existingStatus !== "granted") {
      const { status } = await Permissions.askAsync(Permissions.NOTIFICATIONS);

      finalStatus = status;
      }
      if (finalStatus !== "granted") {
      return;
      } //if "granted" then get push notifications and calls this.savepushtoken to save into the API

      let pushToken = await Notifications.getExpoPushTokenAsync();

      this.subscription = Notifications.addListener(this.handleNotification);
      this.savePushToken(userId, pushToken, token);
      };

      render() {
      return(...)
      }
      }









      share|improve this question













      I'm using Expo to develop both Android and iOS at same time. Notifications were working fine for several weeks, and then out of no where stopped working in production, even though I did not update the app during this time.



      Server-side, everything is still fine, and notifications are being pushed. In dev, notifications are still being received and handled properly, but in production, it's crickets.



      Has anyone else experienced this / what could be causing this?



      Here is my code:



      class Dashboard extends Component {

      constructor(props) {
      super(props);
      this.state = {
      notificationsSet: false,
      }

      }

      componentDidMount() {
      this.registerForPushNotificationsAsync(this.props.currentUser.currentUser.id, this.props.currentUser.authToken)

      savePushToken = (userId, pushToken, token) => {
      //API call to save push token to database
      apiHelper
      .savePushToken(userId, pushToken, token)
      .then(res => {
      return
      })
      .catch(err => console.log("err saving", err));
      };

      handleNotification = notification => {
      this.props.setNotification({ notification })
      }

      registerForPushNotificationsAsync = async (userId, token) =>{
      //requesting if user would like to turn on notifications
      const { status: existingStatus } = await Permissions.getAsync(
      Permissions.NOTIFICATIONS
      );
      //this checks if notifications is turned on for the app --- "granted"
      let finalStatus = existingStatus;
      if (existingStatus !== "granted") {
      const { status } = await Permissions.askAsync(Permissions.NOTIFICATIONS);

      finalStatus = status;
      }
      if (finalStatus !== "granted") {
      return;
      } //if "granted" then get push notifications and calls this.savepushtoken to save into the API

      let pushToken = await Notifications.getExpoPushTokenAsync();

      this.subscription = Notifications.addListener(this.handleNotification);
      this.savePushToken(userId, pushToken, token);
      };

      render() {
      return(...)
      }
      }






      push-notification expo






      share|improve this question













      share|improve this question











      share|improve this question




      share|improve this question










      asked Nov 7 at 18:25









      gwalshington

      9671625




      9671625





























          active

          oldest

          votes











          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',
          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%2f53195578%2fexpo-push-notifications-stopped-working-in-production%23new-answer', 'question_page');
          }
          );

          Post as a guest















          Required, but never shown






























          active

          oldest

          votes













          active

          oldest

          votes









          active

          oldest

          votes






          active

          oldest

          votes
















           

          draft saved


          draft discarded



















































           


          draft saved


          draft discarded














          StackExchange.ready(
          function () {
          StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53195578%2fexpo-push-notifications-stopped-working-in-production%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







          這個網誌中的熱門文章

          Xamarin.form Move up view when keyboard appear

          Post-Redirect-Get with Spring WebFlux and Thymeleaf

          Anylogic : not able to use stopDelay()