mirror of
https://github.com/stackblitz/bolt.new
synced 2025-02-06 04:48:04 +00:00
added cookies storage for git
This commit is contained in:
parent
bbd71e66d4
commit
fecce3fa6a
@ -1,35 +1,38 @@
|
|||||||
import type { WebContainer } from '@webcontainer/api';
|
import type { WebContainer } from '@webcontainer/api';
|
||||||
import { useCallback, useEffect, useRef, useState, type MutableRefObject } from 'react';
|
import { useCallback, useEffect, useRef, useState, type MutableRefObject } from 'react';
|
||||||
import { webcontainer as webcontainerPromise } from '~/lib/webcontainer';
|
import { webcontainer as webcontainerPromise } from '~/lib/webcontainer';
|
||||||
import git, { type PromiseFsClient } from 'isomorphic-git';
|
import git, { type GitAuth, type PromiseFsClient } from 'isomorphic-git';
|
||||||
import http from 'isomorphic-git/http/web';
|
import http from 'isomorphic-git/http/web';
|
||||||
import Cookies from 'js-cookie';
|
import Cookies from 'js-cookie';
|
||||||
import { toast } from 'react-toastify';
|
import { toast } from 'react-toastify';
|
||||||
|
|
||||||
|
const lookupSavedPassword = (url: string) => {
|
||||||
|
const domain = url.split('/')[2];
|
||||||
|
const gitCreds = Cookies.get(`git:${domain}`);
|
||||||
|
|
||||||
|
if (!gitCreds) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
try {
|
||||||
|
const { username, password } = JSON.parse(gitCreds || '{}');
|
||||||
|
return { username, password };
|
||||||
|
} catch (error) {
|
||||||
|
console.log(`Failed to parse Git Cookie ${error}`);
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
const saveGitAuth = (url: string, auth: GitAuth) => {
|
||||||
|
const domain = url.split('/')[2];
|
||||||
|
Cookies.set(`git:${domain}`, JSON.stringify(auth));
|
||||||
|
};
|
||||||
|
|
||||||
export function useGit() {
|
export function useGit() {
|
||||||
const [ready, setReady] = useState(false);
|
const [ready, setReady] = useState(false);
|
||||||
const [webcontainer, setWebcontainer] = useState<WebContainer>();
|
const [webcontainer, setWebcontainer] = useState<WebContainer>();
|
||||||
const [fs, setFs] = useState<PromiseFsClient>();
|
const [fs, setFs] = useState<PromiseFsClient>();
|
||||||
const fileData = useRef<Record<string, { data: any; encoding?: string }>>({});
|
const fileData = useRef<Record<string, { data: any; encoding?: string }>>({});
|
||||||
const lookupSavedPassword: (url: string) => any | null = (url: string) => {
|
|
||||||
try {
|
|
||||||
// Save updated API keys to cookies with 30 day expiry and secure settings
|
|
||||||
const creds = Cookies.get(`git:${url}`);
|
|
||||||
|
|
||||||
if (creds) {
|
|
||||||
const parsedCreds = JSON.parse(creds);
|
|
||||||
|
|
||||||
if (typeof parsedCreds === 'object' && parsedCreds !== null) {
|
|
||||||
return parsedCreds;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return null;
|
|
||||||
} catch (error) {
|
|
||||||
console.error('Error saving API keys to cookies:', error);
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
webcontainerPromise.then((container) => {
|
webcontainerPromise.then((container) => {
|
||||||
fileData.current = {};
|
fileData.current = {};
|
||||||
@ -76,6 +79,9 @@ export function useGit() {
|
|||||||
onAuthFailure: (url, _auth) => {
|
onAuthFailure: (url, _auth) => {
|
||||||
toast.error(`Error Authenticating with ${url.split('/')[2]}`);
|
toast.error(`Error Authenticating with ${url.split('/')[2]}`);
|
||||||
},
|
},
|
||||||
|
onAuthSuccess: (url, auth) => {
|
||||||
|
saveGitAuth(url, auth);
|
||||||
|
},
|
||||||
});
|
});
|
||||||
|
|
||||||
const data: Record<string, { data: any; encoding?: string }> = {};
|
const data: Record<string, { data: any; encoding?: string }> = {};
|
||||||
|
Loading…
Reference in New Issue
Block a user