Skip to content

Commit

Permalink
Merge pull request #233 from tloncorp/hm/hardcode-s3-endpoint
Browse files Browse the repository at this point in the history
storage: hardcode url to mimic groups
  • Loading branch information
arthyn authored Oct 23, 2023
2 parents 7211a66 + 0836413 commit c6b5533
Show file tree
Hide file tree
Showing 4 changed files with 44 additions and 6 deletions.
4 changes: 3 additions & 1 deletion ui/src/env.d.ts
Original file line number Diff line number Diff line change
@@ -1,6 +1,8 @@
interface ImportMetaEnv extends Readonly<Record<string, string | boolean | undefined>> {
interface ImportMetaEnv
extends Readonly<Record<string, string | boolean | undefined>> {
readonly VITE_LAST_WIPE: string;
readonly VITE_STORAGE_VERSION: string;
readonly VITE_SHIP_URL: string;
}

interface ImportMeta {
Expand Down
15 changes: 14 additions & 1 deletion ui/src/logic/utils.ts
Original file line number Diff line number Diff line change
Expand Up @@ -15,8 +15,21 @@ import { useCallback, useState } from 'react';

export const useMockData = import.meta.env.MODE === 'mock';

export const isStagingHosted =
import.meta.env.DEV &&
(import.meta.env.VITE_SHIP_URL.endsWith('.test.tlon.systems') ||
window.location.hostname.endsWith('.test.tlon.systems'));
export const isHosted =
import.meta.env.DEV || window.location.hostname.endsWith('.tlon.network');
isStagingHosted ||
(import.meta.env.DEV &&
(import.meta.env.VITE_SHIP_URL.endsWith('.tlon.network') ||
window.location.hostname.endsWith('.tlon.network')));

export const hostingUploadURL = isStagingHosted
? 'https://memex.test.tlon.systems'
: isHosted
? 'https://memex.tlon.network'
: '';

export async function fakeRequest<T>(data: T, time = 300): Promise<T> {
return new Promise((resolve) => {
Expand Down
7 changes: 5 additions & 2 deletions ui/src/state/storage/reducer.ts
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@ import { StorageUpdate } from '@/gear';
import _ from 'lodash';
import { BaseStorageState } from '@/gear';
import { BaseState } from '../base';
import { hostingUploadURL } from '@/logic/utils';

export type StorageState = BaseStorageState & BaseState<BaseStorageState>;

Expand All @@ -27,8 +28,10 @@ const configuration = (
buckets: new Set(data.buckets),
currentBucket: data.currentBucket,
region: data.region,
presignedUrl: data.presignedUrl,
service: data.service,
// if landscape is not up to date we need to default these so the
// client init logic still works
presignedUrl: data.presignedUrl || hostingUploadURL,
service: data.service || 'credentials',
};
}
return state;
Expand Down
24 changes: 22 additions & 2 deletions ui/src/state/storage/storage.ts
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@ import {
reduceStateN,
BaseState,
} from '../base';
import { hostingUploadURL, isHosted } from '@/logic/utils';

enableMapSet();

Expand All @@ -25,7 +26,7 @@ export const useStorage = createState<BaseStorageState>(
buckets: new Set(),
currentBucket: '',
region: '',
presignedUrl: '',
presignedUrl: hostingUploadURL,
service: 'credentials',
},
credentials: null,
Expand All @@ -44,7 +45,26 @@ export const useStorage = createState<BaseStorageState>(
}
numLoads += 1;
if (numLoads === 2) {
set({ loaded: true });
const {
s3: { credentials, configuration },
} = get();

if (!credentials?.endpoint && isHosted) {
set({
loaded: true,
s3: {
credentials,
configuration: {
...configuration,
presignedUrl:
configuration.presignedUrl || hostingUploadURL,
service: 'presigned-url',
},
},
});
} else {
set({ loaded: true });
}
}
}
),
Expand Down

0 comments on commit c6b5533

Please sign in to comment.