Skip to content

Commit

Permalink
[react] automatically propagete tags (se, etc.) as headers for all fe…
Browse files Browse the repository at this point in the history
…tch requests
  • Loading branch information
realkosty committed Nov 28, 2023
1 parent 79bed0b commit 9d29e37
Show file tree
Hide file tree
Showing 6 changed files with 23 additions and 43 deletions.
9 changes: 0 additions & 9 deletions react/src/components/About.js
Original file line number Diff line number Diff line change
Expand Up @@ -25,24 +25,15 @@ class About extends Component {
}

async componentDidMount() {
let se, customerType, email;
Sentry.withScope(function (scope) {
[se, customerType] = [scope._tags.se, scope._tags.customerType];
email = scope._user.email;
});

// Http requests to make in parallel, so the Transaction has more Spans
let request1 = fetch(this.props.backend + '/api', {
method: 'GET',
headers: { se, customerType, email, 'Content-Type': 'application/json' },
});
let request2 = fetch(this.props.backend + '/organization', {
method: 'GET',
headers: { se, customerType, email, 'Content-Type': 'application/json' },
});
let request3 = fetch(this.props.backend + '/connect', {
method: 'GET',
headers: { se, customerType, email, 'Content-Type': 'application/json' },
});

// Need Safari13 in tests/config.py in order for this modern javascript to work in Safari Browser
Expand Down
8 changes: 1 addition & 7 deletions react/src/components/Checkout.js
Original file line number Diff line number Diff line change
Expand Up @@ -38,15 +38,9 @@ function Checkout(props) {
const [form, setForm] = useState(initialFormValues);

async function checkout(cart) {
let se, customerType, email;
Sentry.withScope(function (scope) {
[se, customerType] = [scope._tags.se, scope._tags.customerType];
email = scope._user.email;
});

const response = await fetch(props.backend + '/checkout?v2=true', {
method: 'POST',
headers: { se, customerType, email, 'Content-Type': 'application/json' },
headers: { 'Content-Type': 'application/json' },
body: JSON.stringify({
cart: cart,
form: form,
Expand Down
8 changes: 0 additions & 8 deletions react/src/components/Home.js
Original file line number Diff line number Diff line change
Expand Up @@ -12,19 +12,11 @@ class Home extends Component {
static contextType = Context;

async componentDidMount() {
let se, customerType, email;
Sentry.withScope(function (scope) {
[se, customerType] = [scope._tags.se, scope._tags.customerType];
email = scope._user.email;
});
try {
// This should be the only http request for home page, for health check purposes
await fetch(this.props.backend + '/success', {
method: 'GET',
headers: {
se,
customerType,
email,
'Content-Type': 'application/json',
},
});
Expand Down
12 changes: 1 addition & 11 deletions react/src/components/Products.js
Original file line number Diff line number Diff line change
Expand Up @@ -19,19 +19,10 @@ class Products extends Component {

// getProducts handles error responses differently, depending on the browser used
async getProducts(frontendSlowdown) {
let se, customerType, email;
Sentry.withScope(function (scope) {
[se, customerType] = [scope._tags.se, scope._tags.customerType];
email = scope._user.email;
});

[('/api', '/connect', '/organization')].forEach((endpoint) => {
fetch(this.props.backend + endpoint, {
method: 'GET',
headers: {
se,
customerType,
email,
'Content-Type': 'application/json',
},
}).catch((err) => {
Expand All @@ -47,8 +38,7 @@ class Products extends Component {
console.log(`productsEndpoint: ${productsEndpoint}`);
let result = await fetch(this.props.backend + productsEndpoint, {
method: 'GET',
method: 'GET',
headers: { se, customerType, email, 'Content-Type': 'application/json' },
headers: { 'Content-Type': 'application/json' },
}).catch((err) => {
return { ok: false, status: 500 };
});
Expand Down
8 changes: 1 addition & 7 deletions react/src/components/ProductsJoin.js
Original file line number Diff line number Diff line change
Expand Up @@ -12,15 +12,9 @@ class ProductsJoin extends Component {

// getProductsJoin handles error responses differently, depending on the browser used
async getProductsJoin() {
let se, customerType, email;
Sentry.withScope(function (scope) {
[se, customerType] = [scope._tags.se, scope._tags.customerType];
email = scope._user.email;
});

let result = await fetch(this.props.backend + '/products-join', {
method: 'GET',
headers: { se, customerType, email, 'Content-Type': 'application/json' },
headers: { 'Content-Type': 'application/json' },
}).catch((err) => {
return { ok: false, status: 500 };
});
Expand Down
21 changes: 20 additions & 1 deletion react/src/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -173,7 +173,7 @@ class App extends Component {

console.log(`> backendType: ${backendType} | backendUrl: ${BACKEND_URL}`);

// These also get passed via request headers
// These also get passed via request headers (see window.fetch below)
Sentry.configureScope((scope) => {
const customerType = [
'medium-plan',
Expand Down Expand Up @@ -250,6 +250,25 @@ class App extends Component {
scope.setUser({ email: email });
});

// Automatically append `se`, `customerType` and `userEmail` query params to all requests
// (except for requests to Sentry)
const nativeFetch = window.fetch;
window.fetch = function(...args) {
let url = args[0];
// When TDA is run in 'mock' mode inside Docker mini-relay will be ingesting on port 9989, see:
// https://github.com/sentry-demos/empower/blob/79bed0b78fb3d40dff30411ef26c31dc7d4838dc/mini-relay/Dockerfile#L9
let ignore_match = url.match(/^http[s]:\/\/([^.]+\.ingest\.sentry\.io\/|localhost:9989|127.0.0.1:9989).*/);
if (!ignore_match) {
Sentry.withScope(function (scope) {
let se, customerType, email;
[se, customerType] = [scope._tags.se, scope._tags.customerType];
email = scope._user.email;
args[1].headers = {...args[1].headers, se, customerType, email};
});
}
return nativeFetch.apply(window, args);
};

// Crasher parses query params sent by /tests for triggering crashes for Release Health
crasher();
}
Expand Down

0 comments on commit 9d29e37

Please sign in to comment.