• Home
  • Features
  • Pricing
  • Docs
  • Announcements
  • Sign In

mozilla / fx-private-relay / 1f27d7ef-045c-4b13-be21-3a6fa9a7e5a6

11 Apr 2025 10:13PM CUT coverage: 85.212% (+0.01%) from 85.201%
1f27d7ef-045c-4b13-be21-3a6fa9a7e5a6

Pull #5500

circleci

groovecoder
MPP-4012 - feat(glean): log API access as Glean server event

Introduce a new `api.accessed` Glean event to capture accesses to Relay API
endpoints. This includes the HTTP method and endpoint path, and logs events
for all `/api/` prefixed routes via a new middleware component.

- Added `record_api_accessed()` to `EventsServerEventLogger`
- Extended `RelayGleanLogger` with `log_api_accessed()` for easier integration
- Registered `GleanApiAccessMiddleware` to log access for all API routes
- Added corresponding unit test for API access logging
- Updated `relay-server-metrics.yaml` to define the `api.accessed` metric
- Updated notification email for several existing metrics to use relay-team@mozilla.com
Pull Request #5500: WIP: MPP-4012 - feat(glean): log API access as Glean server event

2461 of 3597 branches covered (68.42%)

Branch coverage included in aggregate %.

38 of 39 new or added lines in 5 files covered. (97.44%)

1 existing line in 1 file now uncovered.

17258 of 19544 relevant lines covered (88.3%)

9.83 hits per line

Source File
Press 'n' to go to next uncovered line, 'b' for previous

0.0
/frontend/src/components/Localized.tsx
1
// Imports of `Localized` from @fluent/react are forbidden because the component
2
// in this file should be used instead, but of course this component can use it
3
// just fine:
4
// eslint-disable-next-line no-restricted-imports
5
import { LocalizedProps, Localized as OriginalLocalized } from "@fluent/react";
×
6
import { cloneElement, isValidElement, useEffect, useState } from "react";
×
7
import { useL10n } from "../hooks/l10n";
×
8

9
/**
10
 * Wraps @fluent/react's Localized to be consistent between prerender and first render
11
 *
12
 * React will throw a tantrum if the HTML rendered during the build differs from
13
 * the DOM rendered by React when running client-side. However, at build-time we
14
 * don't yet know the user's locale. Thus, if we render strings in the user's
15
 * locale on the first client-side render, we'll make React unhappy, and who
16
 * wants that?
17
 *
18
 * To work around this, the useL10n hook makes sure that the English strings are
19
 * rendered when both prerendering and doing the first client-side render, and
20
 * only after that use the language that aligns with the user's preferences.
21
 * Thus, while pre-rendering and during the first client-side render, we call
22
 * out to that hook.
23
 *
24
 * This means tags embedded in the localised strings won't get added initially,
25
 * but since that's only for SEO and the initial render, that's acceptable.
26
 */
27
export const Localized = (props: LocalizedProps) => {
×
28
  const [isPrerendering, setIsPrerendering] = useState(true);
×
29
  const l10n = useL10n();
×
30

31
  useEffect(() => {
×
32
    setIsPrerendering(false);
×
33
  }, []);
34

35
  if (isPrerendering) {
×
36
    // `useL10n` makes sure that this is a prerenderable string
37
    return isValidElement(props.children) ? (
38
      cloneElement(
×
39
        props.children,
40
        {},
41
        <>{l10n.getString(props.id, props.vars)}</>,
42
      )
43
    ) : (
44
      <>{l10n.getString(props.id, props.vars)}</>
45
    );
46
  }
47

48
  return <OriginalLocalized {...props} />;
49
};
STATUS · Troubleshooting · Open an Issue · Sales · Support · CAREERS · ENTERPRISE · START FREE · SCHEDULE DEMO
ANNOUNCEMENTS · TWITTER · TOS & SLA · Supported CI Services · What's a CI service? · Automated Testing

© 2025 Coveralls, Inc