This commit is contained in:
Ren Amamiya
2023-06-25 15:50:34 +07:00
parent 85b30f770c
commit fe25dbaed0
43 changed files with 933 additions and 402 deletions

View File

@@ -1,121 +0,0 @@
import {
addBlockToDB,
createAccount,
getActiveAccount,
getBlocks,
getLastLogin,
removeBlockFromDB,
updateAccount,
} from "@libs/storage";
import { create } from "zustand";
import { createJSONStorage, persist } from "zustand/middleware";
import { immer } from "zustand/middleware/immer";
export const useActiveAccount = create(
immer(
persist(
(set: any, get: any) => ({
tempProfile: {},
account: null,
blocks: null,
lastLogin: null,
createTempProfile: (data: any) => {
set({ tempProfile: data });
},
create: async (npub: string, pubkey: string, privkey: string) => {
const response = await createAccount(npub, pubkey, privkey, null, 1);
if (response) {
const activeAccount = await getActiveAccount();
await addBlockToDB(
activeAccount.id,
0,
"Lume ❤️ You",
"https://void.cat/d/5FdJcBP5ZXKAjYqV8hpcp3",
);
set({
account: activeAccount,
});
}
},
fetch: async () => {
const response = await getActiveAccount();
set({ account: response });
},
fetchLastLogin: async () => {
const response = await getLastLogin();
set({ lastLogin: parseInt(response) });
},
fetchBlocks: async () => {
const account = get().account;
const response = await getBlocks(account.id);
set({ blocks: response });
},
addTempBlock: (
block: number,
kind: number,
title: string,
content: string,
) => {
const account = get().account;
const target = get().blocks.findIndex(
(b: { id: number }) => b.id === block,
);
// update state
set((state: any) => {
state.blocks.splice(target, 0, {
id: account.id + kind,
account_id: account.id,
kind,
title,
content,
});
});
},
addBlock: (kind: number, title: string, content: string) => {
const account = get().account;
// add to db
addBlockToDB(account.id, kind, title, content);
// update state
set((state: any) => ({
blocks: [
...state.blocks,
{
id: account.id + kind,
account_id: account.id,
kind,
title,
content,
},
],
}));
},
removeBlock: (id: string, db?: false) => {
if (db) {
// remove from db
removeBlockFromDB(id);
}
// update state
set((state: any) => {
const target = state.blocks.findIndex(
(b: { id: string }) => b.id === id,
);
state.blocks.splice(target, 1);
});
},
updateFollows: (list: any) => {
const account = get().account;
// update db
updateAccount("follows", list, account.pubkey);
// update state
set((state: any) => ({
account: { ...state.account, follows: JSON.stringify(list) },
}));
},
}),
{
name: "account",
storage: createJSONStorage(() => sessionStorage),
},
),
),
);

View File

@@ -2,7 +2,66 @@ export const APP_VERSION = "1.0.0";
export const DEFAULT_AVATAR = "https://void.cat/d/5VKmKyuHyxrNMf9bWSVPih";
export const OPENGRAPH_KEY = "9EJG4SY-19Q4M5J-H8R29C9-091XPCC";
export const OPENGRAPH = {
REGEX_VALID_URL: new RegExp(
"^" +
// protocol identifier
"(?:(?:https?|ftp)://)" +
// user:pass authentication
"(?:\\S+(?::\\S*)?@)?" +
"(?:" +
// IP address exclusion
// private & local networks
"(?!(?:10|127)(?:\\.\\d{1,3}){3})" +
"(?!(?:169\\.254|192\\.168)(?:\\.\\d{1,3}){2})" +
"(?!172\\.(?:1[6-9]|2\\d|3[0-1])(?:\\.\\d{1,3}){2})" +
// IP address dotted notation octets
// excludes loopback network 0.0.0.0
// excludes reserved space >= 224.0.0.0
// excludes network & broacast addresses
// (first & last IP address of each class)
"(?:[1-9]\\d?|1\\d\\d|2[01]\\d|22[0-3])" +
"(?:\\.(?:1?\\d{1,2}|2[0-4]\\d|25[0-5])){2}" +
"(?:\\.(?:[1-9]\\d?|1\\d\\d|2[0-4]\\d|25[0-4]))" +
"|" +
// host name
"(?:(?:[a-z\\u00a1-\\uffff0-9]-*)*[a-z\\u00a1-\\uffff0-9]+)" +
// domain name
"(?:\\.(?:[a-z\\u00a1-\\uffff0-9]-*)*[a-z\\u00a1-\\uffff0-9]+)*" +
// TLD identifier
"(?:\\.(?:[a-z\\u00a1-\\uffff]{2,}))" +
// TLD may end with dot
"\\.?" +
")" +
// port number
"(?::\\d{2,5})?" +
// resource path
"(?:[/?#]\\S*)?" +
"$",
"i",
),
REGEX_LOOPBACK: new RegExp(
"^" +
"(?:(?:10|127)(?:\\.\\d{1,3}){3})" +
"|" +
"(?:(?:169\\.254|192\\.168|192\\.0)(?:\\.\\d{1,3}){2})" +
"|" +
"(?:172\\.(?:1[6-9]|2\\d|3[0-1])(?:\\.\\d{1,3}){2})" +
"$",
"i",
),
REGEX_CONTENT_TYPE_IMAGE: new RegExp("image/.*", "i"),
REGEX_CONTENT_TYPE_AUDIO: new RegExp("audio/.*", "i"),
REGEX_CONTENT_TYPE_VIDEO: new RegExp("video/.*", "i"),
REGEX_CONTENT_TYPE_TEXT: new RegExp("text/.*", "i"),
REGEX_CONTENT_TYPE_APPLICATION: new RegExp("application/.*", "i"),
};
export const FULL_RELAYS = [
"wss://relay.damus.io",