useProjectSdkNeedsUpdate.tsx 1.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. import type {Organization} from 'sentry/types/organization';
  2. import {useQuery} from 'sentry/utils/queryClient';
  3. import useApi from 'sentry/utils/useApi';
  4. import {semverCompare} from 'sentry/utils/versions/semverCompare';
  5. type Opts = {
  6. minVersion: string;
  7. organization: Organization;
  8. projectId: string[];
  9. };
  10. function useProjectSdkNeedsUpdate({
  11. minVersion,
  12. organization,
  13. projectId,
  14. }: Opts):
  15. | {isError: false; isFetching: true; needsUpdate: undefined}
  16. | {isError: true; isFetching: false; needsUpdate: undefined}
  17. | {isError: false; isFetching: false; needsUpdate: boolean} {
  18. const path = `/organizations/${organization.slug}/sdk-updates/`;
  19. const api = useApi({persistInFlight: true});
  20. const {data, isLoading, isError} = useQuery(
  21. [path],
  22. async () => {
  23. try {
  24. return await api.requestPromise(path, {
  25. method: 'GET',
  26. });
  27. } catch {
  28. return [];
  29. }
  30. },
  31. {staleTime: 5000, refetchOnMount: false}
  32. );
  33. if (isLoading) {
  34. return {isError: false, isFetching: true, needsUpdate: undefined};
  35. }
  36. if (isError) {
  37. return {isError: true, isFetching: false, needsUpdate: undefined};
  38. }
  39. const selectedProjects = data.filter(sdkUpdate =>
  40. projectId.includes(sdkUpdate.projectId)
  41. );
  42. const needsUpdate =
  43. selectedProjects.length > 0 &&
  44. selectedProjects.every(
  45. sdkUpdate => semverCompare(sdkUpdate.sdkVersion || '', minVersion) === -1
  46. );
  47. return {
  48. isError: false,
  49. isFetching: false,
  50. needsUpdate,
  51. };
  52. }
  53. export default useProjectSdkNeedsUpdate;