# include using namespace std; typedef long long ll; # define int long long # define lc u << 1 # define rc u << 1 | 1 # define fi first # define se second const int N = 1000005, mod = 1e9 + 7; int n, q; int x[N], y[N]; signed main () { // freopen ("generator.in", "r", stdin); freopen ("generator.out", "w", stdout); scanf ("%lld%lld", &n, &q); while (q -- ) { char op; int k; scanf (" %c%lld", &op, &k); if (op == 'x') scanf ("%lld", &x[k]); else if (op == 'y') scanf ("%lld", &y[k]); else if (op == 'a') { int a = 1, b = 1; for (int i = 0; i < k; i ++ ) { if (x[i]) a = (a + x[i] * b % mod * b % mod) % mod; if (y[i]) b = (b * y[i] + 1) % mod; else b = 1; } printf ("%lld\n", a); } } return 0; }