Merge commit '6aeb162927e6f9bbfd597632a10d82d9656c2385' into glitch-soc/merge-upstream
Conflicts: - `.github/dependabot.yml`: We deleted it. Kept it removed. - `app/javascript/packs/public.jsx`: Upstream changed an import, we have slightly different ones. Ported upstream changes.
This commit is contained in:
		| @@ -157,7 +157,7 @@ Metrics/MethodLength: | ||||
|     - 'lib/mastodon/*_cli.rb' | ||||
|  | ||||
| # Reason: | ||||
| # https://docs.rubocop.org/rubocop/cops_style.html#stylerescuestandarderror | ||||
| # https://docs.rubocop.org/rubocop/cops_metrics.html#metricsmodulelength | ||||
| Metrics/ModuleLength: | ||||
|   CountAsOne: [array, heredoc] | ||||
|  | ||||
|   | ||||
| @@ -1,7 +1,7 @@ | ||||
| import React from 'react'; | ||||
| import { Provider } from 'react-redux'; | ||||
| import PropTypes from 'prop-types'; | ||||
| import { store } from '../store/configureStore'; | ||||
| import { store } from '../store'; | ||||
| import { hydrateStore } from '../actions/store'; | ||||
| import { IntlProvider, addLocaleData } from 'react-intl'; | ||||
| import { getLocale } from '../locales'; | ||||
|   | ||||
| @@ -5,7 +5,7 @@ import { IntlProvider, addLocaleData } from 'react-intl'; | ||||
| import { Provider as ReduxProvider } from 'react-redux'; | ||||
| import { BrowserRouter, Route } from 'react-router-dom'; | ||||
| import { ScrollContext } from 'react-router-scroll-4'; | ||||
| import { store } from 'mastodon/store/configureStore'; | ||||
| import { store } from 'mastodon/store'; | ||||
| import UI from 'mastodon/features/ui'; | ||||
| import { fetchCustomEmojis } from 'mastodon/actions/custom_emojis'; | ||||
| import { hydrateStore } from 'mastodon/actions/store'; | ||||
|   | ||||
| @@ -16,10 +16,6 @@ export const layoutFromWindow = (): LayoutType => { | ||||
|   } | ||||
| }; | ||||
|  | ||||
| // eslint-disable-next-line @typescript-eslint/ban-ts-comment | ||||
| // @ts-expect-error | ||||
| const iOS = /iPad|iPhone|iPod/.test(navigator.userAgent) && window.MSStream != null; | ||||
|  | ||||
| const listenerOptions = supportsPassiveEvents ? { passive: true } : false; | ||||
|  | ||||
| let userTouching = false; | ||||
| @@ -33,5 +29,3 @@ const touchListener = () => { | ||||
| window.addEventListener('touchstart', touchListener, listenerOptions); | ||||
|  | ||||
| export const isUserTouching = () => userTouching; | ||||
|  | ||||
| export const isIOS = () => iOS; | ||||
|   | ||||
| @@ -2,7 +2,7 @@ import React from 'react'; | ||||
| import ReactDOM from 'react-dom'; | ||||
| import { setupBrowserNotifications } from 'mastodon/actions/notifications'; | ||||
| import Mastodon from 'mastodon/containers/mastodon'; | ||||
| import { store } from 'mastodon/store/configureStore'; | ||||
| import { store } from 'mastodon/store'; | ||||
| import { me } from 'mastodon/initial_state'; | ||||
| import ready from 'mastodon/ready'; | ||||
| import * as perf from 'mastodon/performance'; | ||||
|   | ||||
| @@ -1,26 +1,16 @@ | ||||
| import 'intl'; | ||||
| import 'intl/locale-data/jsonp/en'; | ||||
| import 'es6-symbol/implement'; | ||||
| import assign from 'object-assign'; | ||||
| import values from 'object.values'; | ||||
| import { decode as decodeBase64 } from './utils/base64'; | ||||
| import promiseFinally from 'promise.prototype.finally'; | ||||
| 
 | ||||
| if (!Object.assign) { | ||||
|   Object.assign = assign; | ||||
| } | ||||
| 
 | ||||
| if (!Object.values) { | ||||
|   values.shim(); | ||||
| } | ||||
| 
 | ||||
| promiseFinally.shim(); | ||||
| import 'core-js/features/object/assign'; | ||||
| import 'core-js/features/object/values'; | ||||
| import 'core-js/features/symbol'; | ||||
| import 'core-js/features/promise/finally'; | ||||
| import { decode as decodeBase64 } from '../utils/base64'; | ||||
| 
 | ||||
| if (!HTMLCanvasElement.prototype.toBlob) { | ||||
|   const BASE64_MARKER = ';base64,'; | ||||
| 
 | ||||
|   Object.defineProperty(HTMLCanvasElement.prototype, 'toBlob', { | ||||
|     value(callback, type = 'image/png', quality) { | ||||
|     value(callback: BlobCallback, type = 'image/png', quality: any)  { | ||||
|       const dataURL = this.toDataURL(type, quality); | ||||
|       let data; | ||||
| 
 | ||||
| @@ -10,14 +10,14 @@ function importExtraPolyfills() { | ||||
|   return import(/* webpackChunkName: "extra_polyfills" */ './extra_polyfills'); | ||||
| } | ||||
| 
 | ||||
| function loadPolyfills() { | ||||
| export function loadPolyfills() { | ||||
|   const needsBasePolyfills = !( | ||||
|     HTMLCanvasElement.prototype.toBlob && | ||||
|     window.Intl && | ||||
|     Object.assign && | ||||
|     Object.values && | ||||
|     window.Symbol && | ||||
|     Promise.prototype.finally | ||||
|     'toBlob' in HTMLCanvasElement.prototype && | ||||
|     'Intl' in window && | ||||
|     'assign' in Object && | ||||
|     'values' in Object && | ||||
|     'Symbol' in window && | ||||
|     'finally' in Promise.prototype | ||||
|   ); | ||||
| 
 | ||||
|   // Latest version of Firefox and Safari do not have IntersectionObserver.
 | ||||
| @@ -36,5 +36,3 @@ function loadPolyfills() { | ||||
|     needsExtraPolyfills && importExtraPolyfills(), | ||||
|   ]); | ||||
| } | ||||
| 
 | ||||
| export default loadPolyfills; | ||||
| @@ -87,4 +87,6 @@ const reducers = { | ||||
|   followed_tags, | ||||
| }; | ||||
| 
 | ||||
| export default combineReducers(reducers); | ||||
| const rootReducer = combineReducers(reducers); | ||||
| 
 | ||||
| export { rootReducer }; | ||||
| @@ -1,16 +0,0 @@ | ||||
| import { configureStore } from '@reduxjs/toolkit'; | ||||
| import thunk from 'redux-thunk'; | ||||
| import appReducer from '../reducers'; | ||||
| import loadingBarMiddleware from '../middleware/loading_bar'; | ||||
| import errorsMiddleware from '../middleware/errors'; | ||||
| import soundsMiddleware from '../middleware/sounds'; | ||||
|  | ||||
| export const store = configureStore({ | ||||
|   reducer: appReducer, | ||||
|   middleware: [ | ||||
|     thunk, | ||||
|     loadingBarMiddleware({ promiseTypeSuffixes: ['REQUEST', 'SUCCESS', 'FAIL'] }), | ||||
|     errorsMiddleware(), | ||||
|     soundsMiddleware(), | ||||
|   ], | ||||
| }); | ||||
							
								
								
									
										23
									
								
								app/javascript/mastodon/store/index.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										23
									
								
								app/javascript/mastodon/store/index.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,23 @@ | ||||
| import { configureStore } from '@reduxjs/toolkit'; | ||||
| import { rootReducer } from '../reducers'; | ||||
| import { loadingBarMiddleware } from './middlewares/loading_bar'; | ||||
| import { errorsMiddleware } from './middlewares/errors'; | ||||
| import { soundsMiddleware } from './middlewares/sounds'; | ||||
| import { TypedUseSelectorHook, useDispatch, useSelector } from 'react-redux'; | ||||
|  | ||||
| export const store = configureStore({ | ||||
|   reducer: rootReducer, | ||||
|   middleware: getDefaultMiddleware => | ||||
|     getDefaultMiddleware().concat( | ||||
|       loadingBarMiddleware({ promiseTypeSuffixes: ['REQUEST', 'SUCCESS', 'FAIL'] })) | ||||
|       .concat(errorsMiddleware) | ||||
|       .concat(soundsMiddleware()), | ||||
| }); | ||||
|  | ||||
| // Infer the `RootState` and `AppDispatch` types from the store itself | ||||
| export type RootState = ReturnType<typeof rootReducer> | ||||
| // Inferred type: {posts: PostsState, comments: CommentsState, users: UsersState} | ||||
| export type AppDispatch = typeof store.dispatch | ||||
|  | ||||
| export const useAppDispatch: () => AppDispatch = useDispatch; | ||||
| export const useAppSelector: TypedUseSelectorHook<RootState> = useSelector; | ||||
| @@ -1,9 +1,11 @@ | ||||
| import { showAlertForError } from '../actions/alerts'; | ||||
| import { Middleware } from 'redux'; | ||||
| import { showAlertForError } from '../../actions/alerts'; | ||||
| import { RootState } from '..'; | ||||
| 
 | ||||
| const defaultFailSuffix = 'FAIL'; | ||||
| 
 | ||||
| export default function errorsMiddleware() { | ||||
|   return ({ dispatch }) => next => action => { | ||||
| export const errorsMiddleware: Middleware<Record<string, never>, RootState> = | ||||
|   ({ dispatch }) => next => action => { | ||||
|     if (action.type && !action.skipAlert) { | ||||
|       const isFail = new RegExp(`${defaultFailSuffix}$`, 'g'); | ||||
| 
 | ||||
| @@ -14,4 +16,3 @@ export default function errorsMiddleware() { | ||||
| 
 | ||||
|     return next(action); | ||||
|   }; | ||||
| } | ||||
| @@ -1,8 +1,14 @@ | ||||
| import { showLoading, hideLoading } from 'react-redux-loading-bar'; | ||||
| import { Middleware } from 'redux'; | ||||
| import { RootState } from '..'; | ||||
| 
 | ||||
| const defaultTypeSuffixes = ['PENDING', 'FULFILLED', 'REJECTED']; | ||||
| interface Config { | ||||
|   promiseTypeSuffixes?: string[] | ||||
| } | ||||
| 
 | ||||
| export default function loadingBarMiddleware(config = {}) { | ||||
| const defaultTypeSuffixes: Config['promiseTypeSuffixes'] = ['PENDING', 'FULFILLED', 'REJECTED']; | ||||
| 
 | ||||
| export  const loadingBarMiddleware = (config: Config = {}): Middleware<Record<string, never>, RootState> => { | ||||
|   const promiseTypeSuffixes = config.promiseTypeSuffixes || defaultTypeSuffixes; | ||||
| 
 | ||||
|   return ({ dispatch }) => next => (action) => { | ||||
| @@ -22,4 +28,4 @@ export default function loadingBarMiddleware(config = {}) { | ||||
| 
 | ||||
|     return next(action); | ||||
|   }; | ||||
| } | ||||
| }; | ||||
| @@ -1,4 +1,12 @@ | ||||
| const createAudio = sources => { | ||||
| import { Middleware, AnyAction } from 'redux'; | ||||
| import { RootState } from '..'; | ||||
| 
 | ||||
| interface AudioSource { | ||||
|   src: string | ||||
|   type: string | ||||
| } | ||||
| 
 | ||||
| const createAudio = (sources: AudioSource[]) => { | ||||
|   const audio = new Audio(); | ||||
|   sources.forEach(({ type, src }) => { | ||||
|     const source = document.createElement('source'); | ||||
| @@ -9,7 +17,7 @@ const createAudio = sources => { | ||||
|   return audio; | ||||
| }; | ||||
| 
 | ||||
| const play = audio => { | ||||
| const play = (audio: HTMLAudioElement) => { | ||||
|   if (!audio.paused) { | ||||
|     audio.pause(); | ||||
|     if (typeof audio.fastSeek === 'function') { | ||||
| @@ -22,8 +30,8 @@ const play = audio => { | ||||
|   audio.play(); | ||||
| }; | ||||
| 
 | ||||
| export default function soundsMiddleware() { | ||||
|   const soundCache = { | ||||
| export  const soundsMiddleware = (): Middleware<Record<string, never>, RootState> => { | ||||
|   const soundCache: {[key: string]: HTMLAudioElement} = { | ||||
|     boop: createAudio([ | ||||
|       { | ||||
|         src: '/sounds/boop.ogg', | ||||
| @@ -36,11 +44,13 @@ export default function soundsMiddleware() { | ||||
|     ]), | ||||
|   }; | ||||
| 
 | ||||
|   return () => next => action => { | ||||
|     if (action.meta && action.meta.sound && soundCache[action.meta.sound]) { | ||||
|       play(soundCache[action.meta.sound]); | ||||
|   return () => next => (action: AnyAction) => { | ||||
|     const sound = action?.meta?.sound; | ||||
| 
 | ||||
|     if (sound && soundCache[sound]) { | ||||
|       play(soundCache[sound]); | ||||
|     } | ||||
| 
 | ||||
|     return next(action); | ||||
|   }; | ||||
| } | ||||
| }; | ||||
| @@ -1,5 +1,5 @@ | ||||
| import './public-path'; | ||||
| import loadPolyfills from '../mastodon/load_polyfills'; | ||||
| import { loadPolyfills } from '../mastodon/polyfills'; | ||||
| import { start } from '../mastodon/common'; | ||||
|  | ||||
| start(); | ||||
|   | ||||
| @@ -1,8 +1,9 @@ | ||||
| import './public-path'; | ||||
| import loadPolyfills from '../mastodon/load_polyfills'; | ||||
|  | ||||
| import { loadPolyfills } from '../mastodon/polyfills'; | ||||
| import ready from '../mastodon/ready'; | ||||
| import { start } from '../mastodon/common'; | ||||
|  | ||||
| import ready from '../mastodon/ready'; | ||||
| import loadKeyboardExtensions from '../mastodon/load_keyboard_extensions'; | ||||
| import 'cocoon-js-vanilla'; | ||||
| import axios from 'axios'; | ||||
| @@ -11,7 +12,7 @@ import { defineMessages } from 'react-intl'; | ||||
| import * as IntlMessageFormat  from 'intl-messageformat'; | ||||
| import { timeAgoString }  from '../mastodon/components/relative_timestamp'; | ||||
| import { delegate }  from '@rails/ujs'; | ||||
| import * as emojify  from '../mastodon/features/emoji/emoji'; | ||||
| import emojify  from '../mastodon/features/emoji/emoji'; | ||||
| import { getLocale }  from '../mastodon/locales'; | ||||
| import React  from 'react'; | ||||
| import ReactDOM  from 'react-dom'; | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
| import './public-path'; | ||||
| import loadPolyfills from '../mastodon/load_polyfills'; | ||||
| import { loadPolyfills } from '../mastodon/polyfills'; | ||||
| import { start } from '../mastodon/common'; | ||||
| import ready from '../mastodon/ready'; | ||||
| import ComposeContainer  from '../mastodon/containers/compose_container'; | ||||
|   | ||||
| @@ -1,10 +1,54 @@ | ||||
| import type { Record } from 'immutable'; | ||||
|  | ||||
| type AccountValues = { | ||||
|   id: number; | ||||
| type CustomEmoji = Record<{ | ||||
|   shortcode: string; | ||||
|   static_url: string; | ||||
|   url: string; | ||||
| }>; | ||||
|  | ||||
| type AccountField = Record<{ | ||||
|   name: string; | ||||
|   value: string; | ||||
|   verified_at: string | null; | ||||
| }>; | ||||
|  | ||||
| type AccountApiResponseValues = { | ||||
|   acct: string; | ||||
|   avatar: string; | ||||
|   avatar_static: string; | ||||
|   [key: string]: any; | ||||
|   bot: boolean; | ||||
|   created_at: string; | ||||
|   discoverable: boolean; | ||||
|   display_name: string; | ||||
|   emojis: CustomEmoji[]; | ||||
|   fields: AccountField[]; | ||||
|   followers_count: number; | ||||
|   following_count: number; | ||||
|   group: boolean; | ||||
|   header: string; | ||||
|   header_static: string; | ||||
|   id: string; | ||||
|   last_status_at: string; | ||||
|   locked: boolean; | ||||
|   note: string; | ||||
|   statuses_count: number; | ||||
|   url: string; | ||||
|   username: string; | ||||
| }; | ||||
|  | ||||
| export type Account = Record<AccountValues>; | ||||
| type NormalizedAccountField = Record<{ | ||||
|   name_emojified: string; | ||||
|   value_emojified: string; | ||||
|   value_plain: string; | ||||
| }>; | ||||
|  | ||||
| type NormalizedAccountValues = { | ||||
|   display_name_html: string; | ||||
|   fields: NormalizedAccountField[]; | ||||
|   note_emojified: string; | ||||
|   note_plain: string; | ||||
| }; | ||||
|  | ||||
| export type Account = Record< | ||||
|   AccountApiResponseValues & NormalizedAccountValues | ||||
| >; | ||||
|   | ||||
| @@ -11,7 +11,7 @@ module Mastodon | ||||
|       true | ||||
|     end | ||||
|  | ||||
|     option :severity, required: true, enum: %w(no_access sign_up_requires_approval), desc: 'Severity of the block' | ||||
|     option :severity, required: true, enum: %w(no_access sign_up_requires_approval sign_up_block), desc: 'Severity of the block' | ||||
|     option :comment, aliases: [:c], desc: 'Optional comment' | ||||
|     option :duration, aliases: [:d], type: :numeric, desc: 'Duration of the block in seconds' | ||||
|     option :force, type: :boolean, aliases: [:f], desc: 'Overwrite existing blocks' | ||||
| @@ -36,6 +36,12 @@ module Mastodon | ||||
|       failed    = 0 | ||||
|  | ||||
|       addresses.each do |address| | ||||
|         unless valid_ip_address?(address) | ||||
|           say("#{address} is invalid", :red) | ||||
|           failed += 1 | ||||
|           next | ||||
|         end | ||||
|  | ||||
|         ip_block = IpBlock.find_by(ip: address) | ||||
|  | ||||
|         if ip_block.present? && !options[:force] | ||||
| @@ -79,6 +85,12 @@ module Mastodon | ||||
|       skipped   = 0 | ||||
|  | ||||
|       addresses.each do |address| | ||||
|         unless valid_ip_address?(address) | ||||
|           say("#{address} is invalid", :yellow) | ||||
|           skipped += 1 | ||||
|           next | ||||
|         end | ||||
|  | ||||
|         ip_blocks = if options[:force] | ||||
|                       IpBlock.where('ip >>= ?', address) | ||||
|                     else | ||||
| @@ -126,5 +138,12 @@ module Mastodon | ||||
|         :red | ||||
|       end | ||||
|     end | ||||
|  | ||||
|     def valid_ip_address?(ip_address) | ||||
|       IPAddr.new(ip_address) | ||||
|       true | ||||
|     rescue IPAddr::InvalidAddressError | ||||
|       false | ||||
|     end | ||||
|   end | ||||
| end | ||||
|   | ||||
							
								
								
									
										13
									
								
								package.json
									
									
									
									
									
								
							
							
						
						
									
										13
									
								
								package.json
									
									
									
									
									
								
							| @@ -53,13 +53,13 @@ | ||||
|     "cocoon-js-vanilla": "^1.3.0", | ||||
|     "color-blend": "^4.0.0", | ||||
|     "compression-webpack-plugin": "^6.1.1", | ||||
|     "core-js": "^3.30.2", | ||||
|     "cross-env": "^7.0.3", | ||||
|     "css-loader": "^5.2.7", | ||||
|     "cssnano": "^6.0.1", | ||||
|     "detect-passive-events": "^2.0.3", | ||||
|     "dotenv": "^16.0.3", | ||||
|     "emoji-mart": "npm:emoji-mart-lazyload@latest", | ||||
|     "es6-symbol": "^3.1.3", | ||||
|     "escape-html": "^1.0.3", | ||||
|     "exif-js": "^2.3.0", | ||||
|     "express": "^4.18.2", | ||||
| @@ -83,14 +83,11 @@ | ||||
|     "mini-css-extract-plugin": "^1.6.2", | ||||
|     "mkdirp": "^2.1.6", | ||||
|     "npmlog": "^7.0.1", | ||||
|     "object-assign": "^4.1.1", | ||||
|     "object.values": "^1.1.6", | ||||
|     "path-complete-extname": "^1.0.0", | ||||
|     "pg": "^8.5.0", | ||||
|     "pg-connection-string": "^2.5.0", | ||||
|     "postcss": "^8.4.23", | ||||
|     "postcss-loader": "^4.3.0", | ||||
|     "promise.prototype.finally": "^3.1.4", | ||||
|     "prop-types": "^15.8.1", | ||||
|     "punycode": "^2.3.0", | ||||
|     "react": "^16.14.0", | ||||
| @@ -129,7 +126,7 @@ | ||||
|     "tesseract.js": "^2.1.5", | ||||
|     "tiny-queue": "^0.2.1", | ||||
|     "twitter-text": "3.1.0", | ||||
|     "uuid": "^8.3.1", | ||||
|     "uuid": "^9.0.0", | ||||
|     "webpack": "^4.46.0", | ||||
|     "webpack-assets-manifest": "^4.0.6", | ||||
|     "webpack-bundle-analyzer": "^4.8.0", | ||||
| @@ -179,11 +176,11 @@ | ||||
|     "@types/react-toggle": "^4.0.3", | ||||
|     "@types/redux-immutable": "^4.0.3", | ||||
|     "@types/requestidlecallback": "^0.3.5", | ||||
|     "@types/uuid": "^8.3.4", | ||||
|     "@types/uuid": "^9.0.0", | ||||
|     "@types/webpack": "^4.41.33", | ||||
|     "@types/yargs": "^17.0.24", | ||||
|     "@typescript-eslint/eslint-plugin": "^5.59.2", | ||||
|     "@typescript-eslint/parser": "^5.59.2", | ||||
|     "@typescript-eslint/eslint-plugin": "^5.59.5", | ||||
|     "@typescript-eslint/parser": "^5.59.5", | ||||
|     "babel-jest": "^29.5.0", | ||||
|     "eslint": "^8.39.0", | ||||
|     "eslint-plugin-formatjs": "^4.10.1", | ||||
|   | ||||
| @@ -2,6 +2,7 @@ | ||||
|   "compilerOptions": { | ||||
|     "jsx": "react", | ||||
|     "target": "esnext", | ||||
|     "module": "CommonJS", | ||||
|     "moduleResolution": "node", | ||||
|     "allowJs": true, | ||||
|     "noEmit": true, | ||||
|   | ||||
							
								
								
									
										182
									
								
								yarn.lock
									
									
									
									
									
								
							
							
						
						
									
										182
									
								
								yarn.lock
									
									
									
									
									
								
							| @@ -2425,10 +2425,10 @@ | ||||
|   dependencies: | ||||
|     source-map "^0.6.1" | ||||
|  | ||||
| "@types/uuid@^8.3.4": | ||||
|   version "8.3.4" | ||||
|   resolved "https://registry.yarnpkg.com/@types/uuid/-/uuid-8.3.4.tgz#bd86a43617df0594787d38b735f55c805becf1bc" | ||||
|   integrity sha512-c/I8ZRb51j+pYGAu5CrFMRxqZ2ke4y2grEBO5AUjgSkSk+qT2Ea+OdWElz/OiMf5MNpn2b17kuVBwZLQJXzihw== | ||||
| "@types/uuid@^9.0.0": | ||||
|   version "9.0.1" | ||||
|   resolved "https://registry.yarnpkg.com/@types/uuid/-/uuid-9.0.1.tgz#98586dc36aee8dacc98cc396dbca8d0429647aa6" | ||||
|   integrity sha512-rFT3ak0/2trgvp4yYZo5iKFEPsET7vKydKF+VRCxlQ9bpheehyAJH89dAkaLEq/j/RZXJIqcgsmPJKUP1Z28HA== | ||||
|  | ||||
| "@types/warning@^3.0.0": | ||||
|   version "3.0.0" | ||||
| @@ -2475,15 +2475,15 @@ | ||||
|   dependencies: | ||||
|     "@types/yargs-parser" "*" | ||||
|  | ||||
| "@typescript-eslint/eslint-plugin@^5.59.2": | ||||
|   version "5.59.2" | ||||
|   resolved "https://registry.yarnpkg.com/@typescript-eslint/eslint-plugin/-/eslint-plugin-5.59.2.tgz#684a2ce7182f3b4dac342eef7caa1c2bae476abd" | ||||
|   integrity sha512-yVrXupeHjRxLDcPKL10sGQ/QlVrA8J5IYOEWVqk0lJaSZP7X5DfnP7Ns3cc74/blmbipQ1htFNVGsHX6wsYm0A== | ||||
| "@typescript-eslint/eslint-plugin@^5.59.5": | ||||
|   version "5.59.5" | ||||
|   resolved "https://registry.yarnpkg.com/@typescript-eslint/eslint-plugin/-/eslint-plugin-5.59.5.tgz#f156827610a3f8cefc56baeaa93cd4a5f32966b4" | ||||
|   integrity sha512-feA9xbVRWJZor+AnLNAr7A8JRWeZqHUf4T9tlP+TN04b05pFVhO5eN7/O93Y/1OUlLMHKbnJisgDURs/qvtqdg== | ||||
|   dependencies: | ||||
|     "@eslint-community/regexpp" "^4.4.0" | ||||
|     "@typescript-eslint/scope-manager" "5.59.2" | ||||
|     "@typescript-eslint/type-utils" "5.59.2" | ||||
|     "@typescript-eslint/utils" "5.59.2" | ||||
|     "@typescript-eslint/scope-manager" "5.59.5" | ||||
|     "@typescript-eslint/type-utils" "5.59.5" | ||||
|     "@typescript-eslint/utils" "5.59.5" | ||||
|     debug "^4.3.4" | ||||
|     grapheme-splitter "^1.0.4" | ||||
|     ignore "^5.2.0" | ||||
| @@ -2491,31 +2491,31 @@ | ||||
|     semver "^7.3.7" | ||||
|     tsutils "^3.21.0" | ||||
|  | ||||
| "@typescript-eslint/parser@^5.59.2": | ||||
|   version "5.59.2" | ||||
|   resolved "https://registry.yarnpkg.com/@typescript-eslint/parser/-/parser-5.59.2.tgz#c2c443247901d95865b9f77332d9eee7c55655e8" | ||||
|   integrity sha512-uq0sKyw6ao1iFOZZGk9F8Nro/8+gfB5ezl1cA06SrqbgJAt0SRoFhb9pXaHvkrxUpZaoLxt8KlovHNk8Gp6/HQ== | ||||
| "@typescript-eslint/parser@^5.59.5": | ||||
|   version "5.59.5" | ||||
|   resolved "https://registry.yarnpkg.com/@typescript-eslint/parser/-/parser-5.59.5.tgz#63064f5eafbdbfb5f9dfbf5c4503cdf949852981" | ||||
|   integrity sha512-NJXQC4MRnF9N9yWqQE2/KLRSOLvrrlZb48NGVfBa+RuPMN6B7ZcK5jZOvhuygv4D64fRKnZI4L4p8+M+rfeQuw== | ||||
|   dependencies: | ||||
|     "@typescript-eslint/scope-manager" "5.59.2" | ||||
|     "@typescript-eslint/types" "5.59.2" | ||||
|     "@typescript-eslint/typescript-estree" "5.59.2" | ||||
|     "@typescript-eslint/scope-manager" "5.59.5" | ||||
|     "@typescript-eslint/types" "5.59.5" | ||||
|     "@typescript-eslint/typescript-estree" "5.59.5" | ||||
|     debug "^4.3.4" | ||||
|  | ||||
| "@typescript-eslint/scope-manager@5.59.2": | ||||
|   version "5.59.2" | ||||
|   resolved "https://registry.yarnpkg.com/@typescript-eslint/scope-manager/-/scope-manager-5.59.2.tgz#f699fe936ee4e2c996d14f0fdd3a7da5ba7b9a4c" | ||||
|   integrity sha512-dB1v7ROySwQWKqQ8rEWcdbTsFjh2G0vn8KUyvTXdPoyzSL6lLGkiXEV5CvpJsEe9xIdKV+8Zqb7wif2issoOFA== | ||||
| "@typescript-eslint/scope-manager@5.59.5": | ||||
|   version "5.59.5" | ||||
|   resolved "https://registry.yarnpkg.com/@typescript-eslint/scope-manager/-/scope-manager-5.59.5.tgz#33ffc7e8663f42cfaac873de65ebf65d2bce674d" | ||||
|   integrity sha512-jVecWwnkX6ZgutF+DovbBJirZcAxgxC0EOHYt/niMROf8p4PwxxG32Qdhj/iIQQIuOflLjNkxoXyArkcIP7C3A== | ||||
|   dependencies: | ||||
|     "@typescript-eslint/types" "5.59.2" | ||||
|     "@typescript-eslint/visitor-keys" "5.59.2" | ||||
|     "@typescript-eslint/types" "5.59.5" | ||||
|     "@typescript-eslint/visitor-keys" "5.59.5" | ||||
|  | ||||
| "@typescript-eslint/type-utils@5.59.2": | ||||
|   version "5.59.2" | ||||
|   resolved "https://registry.yarnpkg.com/@typescript-eslint/type-utils/-/type-utils-5.59.2.tgz#0729c237503604cd9a7084b5af04c496c9a4cdcf" | ||||
|   integrity sha512-b1LS2phBOsEy/T381bxkkywfQXkV1dWda/z0PhnIy3bC5+rQWQDS7fk9CSpcXBccPY27Z6vBEuaPBCKCgYezyQ== | ||||
| "@typescript-eslint/type-utils@5.59.5": | ||||
|   version "5.59.5" | ||||
|   resolved "https://registry.yarnpkg.com/@typescript-eslint/type-utils/-/type-utils-5.59.5.tgz#485b0e2c5b923460bc2ea6b338c595343f06fc9b" | ||||
|   integrity sha512-4eyhS7oGym67/pSxA2mmNq7X164oqDYNnZCUayBwJZIRVvKpBCMBzFnFxjeoDeShjtO6RQBHBuwybuX3POnDqg== | ||||
|   dependencies: | ||||
|     "@typescript-eslint/typescript-estree" "5.59.2" | ||||
|     "@typescript-eslint/utils" "5.59.2" | ||||
|     "@typescript-eslint/typescript-estree" "5.59.5" | ||||
|     "@typescript-eslint/utils" "5.59.5" | ||||
|     debug "^4.3.4" | ||||
|     tsutils "^3.21.0" | ||||
|  | ||||
| @@ -2524,10 +2524,10 @@ | ||||
|   resolved "https://registry.yarnpkg.com/@typescript-eslint/types/-/types-5.59.0.tgz#3fcdac7dbf923ec5251545acdd9f1d42d7c4fe32" | ||||
|   integrity sha512-yR2h1NotF23xFFYKHZs17QJnB51J/s+ud4PYU4MqdZbzeNxpgUr05+dNeCN/bb6raslHvGdd6BFCkVhpPk/ZeA== | ||||
|  | ||||
| "@typescript-eslint/types@5.59.2": | ||||
|   version "5.59.2" | ||||
|   resolved "https://registry.yarnpkg.com/@typescript-eslint/types/-/types-5.59.2.tgz#b511d2b9847fe277c5cb002a2318bd329ef4f655" | ||||
|   integrity sha512-LbJ/HqoVs2XTGq5shkiKaNTuVv5tTejdHgfdjqRUGdYhjW1crm/M7og2jhVskMt8/4wS3T1+PfFvL1K3wqYj4w== | ||||
| "@typescript-eslint/types@5.59.5": | ||||
|   version "5.59.5" | ||||
|   resolved "https://registry.yarnpkg.com/@typescript-eslint/types/-/types-5.59.5.tgz#e63c5952532306d97c6ea432cee0981f6d2258c7" | ||||
|   integrity sha512-xkfRPHbqSH4Ggx4eHRIO/eGL8XL4Ysb4woL8c87YuAo8Md7AUjyWKa9YMwTL519SyDPrfEgKdewjkxNCVeJW7w== | ||||
|  | ||||
| "@typescript-eslint/typescript-estree@5.59.0": | ||||
|   version "5.59.0" | ||||
| @@ -2542,30 +2542,30 @@ | ||||
|     semver "^7.3.7" | ||||
|     tsutils "^3.21.0" | ||||
|  | ||||
| "@typescript-eslint/typescript-estree@5.59.2": | ||||
|   version "5.59.2" | ||||
|   resolved "https://registry.yarnpkg.com/@typescript-eslint/typescript-estree/-/typescript-estree-5.59.2.tgz#6e2fabd3ba01db5d69df44e0b654c0b051fe9936" | ||||
|   integrity sha512-+j4SmbwVmZsQ9jEyBMgpuBD0rKwi9RxRpjX71Brr73RsYnEr3Lt5QZ624Bxphp8HUkSKfqGnPJp1kA5nl0Sh7Q== | ||||
| "@typescript-eslint/typescript-estree@5.59.5": | ||||
|   version "5.59.5" | ||||
|   resolved "https://registry.yarnpkg.com/@typescript-eslint/typescript-estree/-/typescript-estree-5.59.5.tgz#9b252ce55dd765e972a7a2f99233c439c5101e42" | ||||
|   integrity sha512-+XXdLN2CZLZcD/mO7mQtJMvCkzRfmODbeSKuMY/yXbGkzvA9rJyDY5qDYNoiz2kP/dmyAxXquL2BvLQLJFPQIg== | ||||
|   dependencies: | ||||
|     "@typescript-eslint/types" "5.59.2" | ||||
|     "@typescript-eslint/visitor-keys" "5.59.2" | ||||
|     "@typescript-eslint/types" "5.59.5" | ||||
|     "@typescript-eslint/visitor-keys" "5.59.5" | ||||
|     debug "^4.3.4" | ||||
|     globby "^11.1.0" | ||||
|     is-glob "^4.0.3" | ||||
|     semver "^7.3.7" | ||||
|     tsutils "^3.21.0" | ||||
|  | ||||
| "@typescript-eslint/utils@5.59.2": | ||||
|   version "5.59.2" | ||||
|   resolved "https://registry.yarnpkg.com/@typescript-eslint/utils/-/utils-5.59.2.tgz#0c45178124d10cc986115885688db6abc37939f4" | ||||
|   integrity sha512-kSuF6/77TZzyGPhGO4uVp+f0SBoYxCDf+lW3GKhtKru/L8k/Hd7NFQxyWUeY7Z/KGB2C6Fe3yf2vVi4V9TsCSQ== | ||||
| "@typescript-eslint/utils@5.59.5": | ||||
|   version "5.59.5" | ||||
|   resolved "https://registry.yarnpkg.com/@typescript-eslint/utils/-/utils-5.59.5.tgz#15b3eb619bb223302e60413adb0accd29c32bcae" | ||||
|   integrity sha512-sCEHOiw+RbyTii9c3/qN74hYDPNORb8yWCoPLmB7BIflhplJ65u2PBpdRla12e3SSTJ2erRkPjz7ngLHhUegxA== | ||||
|   dependencies: | ||||
|     "@eslint-community/eslint-utils" "^4.2.0" | ||||
|     "@types/json-schema" "^7.0.9" | ||||
|     "@types/semver" "^7.3.12" | ||||
|     "@typescript-eslint/scope-manager" "5.59.2" | ||||
|     "@typescript-eslint/types" "5.59.2" | ||||
|     "@typescript-eslint/typescript-estree" "5.59.2" | ||||
|     "@typescript-eslint/scope-manager" "5.59.5" | ||||
|     "@typescript-eslint/types" "5.59.5" | ||||
|     "@typescript-eslint/typescript-estree" "5.59.5" | ||||
|     eslint-scope "^5.1.1" | ||||
|     semver "^7.3.7" | ||||
|  | ||||
| @@ -2577,12 +2577,12 @@ | ||||
|     "@typescript-eslint/types" "5.59.0" | ||||
|     eslint-visitor-keys "^3.3.0" | ||||
|  | ||||
| "@typescript-eslint/visitor-keys@5.59.2": | ||||
|   version "5.59.2" | ||||
|   resolved "https://registry.yarnpkg.com/@typescript-eslint/visitor-keys/-/visitor-keys-5.59.2.tgz#37a419dc2723a3eacbf722512b86d6caf7d3b750" | ||||
|   integrity sha512-EEpsO8m3RASrKAHI9jpavNv9NlEUebV4qmF1OWxSTtKSFBpC1NCmWazDQHFivRf0O1DV11BA645yrLEVQ0/Lig== | ||||
| "@typescript-eslint/visitor-keys@5.59.5": | ||||
|   version "5.59.5" | ||||
|   resolved "https://registry.yarnpkg.com/@typescript-eslint/visitor-keys/-/visitor-keys-5.59.5.tgz#ba5b8d6791a13cf9fea6716af1e7626434b29b9b" | ||||
|   integrity sha512-qL+Oz+dbeBRTeyJTIy0eniD3uvqU7x+y1QceBismZ41hd4aBSRh8UAw4pZP0+XzLuPZmx4raNMq/I+59W2lXKA== | ||||
|   dependencies: | ||||
|     "@typescript-eslint/types" "5.59.2" | ||||
|     "@typescript-eslint/types" "5.59.5" | ||||
|     eslint-visitor-keys "^3.3.0" | ||||
|  | ||||
| "@webassemblyjs/ast@1.9.0": | ||||
| @@ -4140,6 +4140,11 @@ core-js@^2.5.0: | ||||
|   resolved "https://registry.yarnpkg.com/core-js/-/core-js-2.6.12.tgz#d9333dfa7b065e347cc5682219d6f690859cc2ec" | ||||
|   integrity sha512-Kb2wC0fvsWfQrgk8HU5lW6U/Lcs8+9aaYcy4ZFc6DDlo4nZ7n70dEgE5rtR0oG6ufKDUnrwfWL1mXR5ljDatrQ== | ||||
|  | ||||
| core-js@^3.30.2: | ||||
|   version "3.30.2" | ||||
|   resolved "https://registry.yarnpkg.com/core-js/-/core-js-3.30.2.tgz#6528abfda65e5ad728143ea23f7a14f0dcf503fc" | ||||
|   integrity sha512-uBJiDmwqsbJCWHAwjrx3cvjbMXP7xD72Dmsn5LOJpiRmE3WbBbN5rCqQ2Qh6Ek6/eOrjlWngEynBWo4VxerQhg== | ||||
|  | ||||
| core-util-is@~1.0.0: | ||||
|   version "1.0.2" | ||||
|   resolved "https://registry.yarnpkg.com/core-util-is/-/core-util-is-1.0.2.tgz#b5fd54220aa2bc5ab57aab7140c940754503c1a7" | ||||
| @@ -4414,14 +4419,6 @@ csstype@^3.0.2: | ||||
|   resolved "https://registry.yarnpkg.com/csstype/-/csstype-3.0.6.tgz#865d0b5833d7d8d40f4e5b8a6d76aea3de4725ef" | ||||
|   integrity sha512-+ZAmfyWMT7TiIlzdqJgjMb7S4f1beorDbWbsocyK4RaiqA5RTX3K14bnBWmmA9QEM0gRdsjyyrEmcyga8Zsxmw== | ||||
|  | ||||
| d@1, d@^1.0.1: | ||||
|   version "1.0.1" | ||||
|   resolved "https://registry.yarnpkg.com/d/-/d-1.0.1.tgz#8698095372d58dbee346ffd0c7093f99f8f9eb5a" | ||||
|   integrity sha512-m62ShEObQ39CfralilEQRjH6oAMtNCV1xJyEx5LpRYUVN+EviphDgUc/F3hnYbADmkiNs67Y+3ylmlG7Lnu+FA== | ||||
|   dependencies: | ||||
|     es5-ext "^0.10.50" | ||||
|     type "^1.0.1" | ||||
|  | ||||
| damerau-levenshtein@^1.0.8: | ||||
|   version "1.0.8" | ||||
|   resolved "https://registry.yarnpkg.com/damerau-levenshtein/-/damerau-levenshtein-1.0.8.tgz#b43d286ccbd36bc5b2f7ed41caf2d0aba1f8a6e7" | ||||
| @@ -4972,32 +4969,6 @@ es-to-primitive@^1.2.1: | ||||
|     is-date-object "^1.0.1" | ||||
|     is-symbol "^1.0.2" | ||||
|  | ||||
| es5-ext@^0.10.35, es5-ext@^0.10.50: | ||||
|   version "0.10.53" | ||||
|   resolved "https://registry.yarnpkg.com/es5-ext/-/es5-ext-0.10.53.tgz#93c5a3acfdbef275220ad72644ad02ee18368de1" | ||||
|   integrity sha512-Xs2Stw6NiNHWypzRTY1MtaG/uJlwCk8kH81920ma8mvN8Xq1gsfhZvpkImLQArw8AHnv8MT2I45J3c0R8slE+Q== | ||||
|   dependencies: | ||||
|     es6-iterator "~2.0.3" | ||||
|     es6-symbol "~3.1.3" | ||||
|     next-tick "~1.0.0" | ||||
|  | ||||
| es6-iterator@~2.0.3: | ||||
|   version "2.0.3" | ||||
|   resolved "https://registry.yarnpkg.com/es6-iterator/-/es6-iterator-2.0.3.tgz#a7de889141a05a94b0854403b2d0a0fbfa98f3b7" | ||||
|   integrity sha1-p96IkUGgWpSwhUQDstCg+/qY87c= | ||||
|   dependencies: | ||||
|     d "1" | ||||
|     es5-ext "^0.10.35" | ||||
|     es6-symbol "^3.1.1" | ||||
|  | ||||
| es6-symbol@^3.1.1, es6-symbol@^3.1.3, es6-symbol@~3.1.3: | ||||
|   version "3.1.3" | ||||
|   resolved "https://registry.yarnpkg.com/es6-symbol/-/es6-symbol-3.1.3.tgz#bad5d3c1bcdac28269f4cb331e431c78ac705d18" | ||||
|   integrity sha512-NJ6Yn3FuDinBaBRWl/q5X/s4koRHBrgKAu+yGI6JCBeiu3qrcbJhwT2GeR/EXVfylRk8dpQVJoLEFhK+Mu31NA== | ||||
|   dependencies: | ||||
|     d "^1.0.1" | ||||
|     ext "^1.1.2" | ||||
|  | ||||
| escalade@^3.1.1: | ||||
|   version "3.1.1" | ||||
|   resolved "https://registry.yarnpkg.com/escalade/-/escalade-3.1.1.tgz#d8cfdc7000965c5a0174b4a82eaa5c0552742e40" | ||||
| @@ -5435,13 +5406,6 @@ express@^4.17.1, express@^4.18.2: | ||||
|     utils-merge "1.0.1" | ||||
|     vary "~1.1.2" | ||||
|  | ||||
| ext@^1.1.2: | ||||
|   version "1.4.0" | ||||
|   resolved "https://registry.yarnpkg.com/ext/-/ext-1.4.0.tgz#89ae7a07158f79d35517882904324077e4379244" | ||||
|   integrity sha512-Key5NIsUxdqKg3vIsdw9dSuXpPCQ297y6wBjL30edxwPgt2E44WcWBZey/ZvUc6sERLTxKdyCu4gZFmUbk1Q7A== | ||||
|   dependencies: | ||||
|     type "^2.0.0" | ||||
|  | ||||
| extend-shallow@^2.0.1: | ||||
|   version "2.0.1" | ||||
|   resolved "https://registry.yarnpkg.com/extend-shallow/-/extend-shallow-2.0.1.tgz#51af7d614ad9a9f610ea1bafbb989d6b1c56890f" | ||||
| @@ -8249,11 +8213,6 @@ neo-async@^2.5.0, neo-async@^2.6.1, neo-async@^2.6.2: | ||||
|   resolved "https://registry.yarnpkg.com/neo-async/-/neo-async-2.6.2.tgz#b4aafb93e3aeb2d8174ca53cf163ab7d7308305f" | ||||
|   integrity sha512-Yd3UES5mWCSqR+qNT93S3UoYUkqAZ9lLg8a7g9rimsWmYGK8cVToA4/sF3RrshdyV3sAGMXVUmpMYOw+dLpOuw== | ||||
|  | ||||
| next-tick@~1.0.0: | ||||
|   version "1.0.0" | ||||
|   resolved "https://registry.yarnpkg.com/next-tick/-/next-tick-1.0.0.tgz#ca86d1fe8828169b0120208e3dc8424b9db8342c" | ||||
|   integrity sha1-yobR/ogoFpsBICCOPchCS524NCw= | ||||
|  | ||||
| nice-try@^1.0.4: | ||||
|   version "1.0.5" | ||||
|   resolved "https://registry.yarnpkg.com/nice-try/-/nice-try-1.0.5.tgz#a3378a7696ce7d223e88fc9b764bd7ef1089e366" | ||||
| @@ -9299,15 +9258,6 @@ promise-inflight@^1.0.1: | ||||
|   resolved "https://registry.yarnpkg.com/promise-inflight/-/promise-inflight-1.0.1.tgz#98472870bf228132fcbdd868129bad12c3c029e3" | ||||
|   integrity sha1-mEcocL8igTL8vdhoEputEsPAKeM= | ||||
|  | ||||
| promise.prototype.finally@^3.1.4: | ||||
|   version "3.1.4" | ||||
|   resolved "https://registry.yarnpkg.com/promise.prototype.finally/-/promise.prototype.finally-3.1.4.tgz#4e756a154e4db27fae24c6b18703495c31da3927" | ||||
|   integrity sha512-nNc3YbgMfLzqtqvO/q5DP6RR0SiHI9pUPGzyDf1q+usTwCN2kjvAnJkBb7bHe3o+fFSBPpsGMoYtaSi+LTNqng== | ||||
|   dependencies: | ||||
|     call-bind "^1.0.2" | ||||
|     define-properties "^1.1.4" | ||||
|     es-abstract "^1.20.4" | ||||
|  | ||||
| prompts@^2.0.1: | ||||
|   version "2.3.2" | ||||
|   resolved "https://registry.yarnpkg.com/prompts/-/prompts-2.3.2.tgz#480572d89ecf39566d2bd3fe2c9fccb7c4c0b068" | ||||
| @@ -11441,16 +11391,6 @@ type-is@~1.6.18: | ||||
|     media-typer "0.3.0" | ||||
|     mime-types "~2.1.24" | ||||
|  | ||||
| type@^1.0.1: | ||||
|   version "1.2.0" | ||||
|   resolved "https://registry.yarnpkg.com/type/-/type-1.2.0.tgz#848dd7698dafa3e54a6c479e759c4bc3f18847a0" | ||||
|   integrity sha512-+5nt5AAniqsCnu2cEQQdpzCAh33kVx8n0VoFidKpB1dVVLAN/F+bgVOqOJqOnEnrhp222clB5p3vUlD+1QAnfg== | ||||
|  | ||||
| type@^2.0.0: | ||||
|   version "2.0.0" | ||||
|   resolved "https://registry.yarnpkg.com/type/-/type-2.0.0.tgz#5f16ff6ef2eb44f260494dae271033b29c09a9c3" | ||||
|   integrity sha512-KBt58xCHry4Cejnc2ISQAF7QY+ORngsWfxezO68+12hKV6lQY8P/psIkcbjeHWn7MqcgciWJyCCevFMJdIXpow== | ||||
|  | ||||
| "typescript@^4.7 || 5", typescript@^5.0.4: | ||||
|   version "5.0.4" | ||||
|   resolved "https://registry.yarnpkg.com/typescript/-/typescript-5.0.4.tgz#b217fd20119bd61a94d4011274e0ab369058da3b" | ||||
| @@ -11669,10 +11609,10 @@ uuid@^3.3.2, uuid@^3.4.0: | ||||
|   resolved "https://registry.yarnpkg.com/uuid/-/uuid-3.4.0.tgz#b23e4358afa8a202fe7a100af1f5f883f02007ee" | ||||
|   integrity sha512-HjSDRw6gZE5JMggctHBcjVak08+KEVhSIiDzFnT9S9aegmp85S/bReBVTb4QTFaRNptJ9kuYaNhnbNEOkbKb/A== | ||||
|  | ||||
| uuid@^8.3.1: | ||||
|   version "8.3.2" | ||||
|   resolved "https://registry.yarnpkg.com/uuid/-/uuid-8.3.2.tgz#80d5b5ced271bb9af6c445f21a1a04c606cefbe2" | ||||
|   integrity sha512-+NYs2QeMWy+GWFOEm9xnn6HCDp0l7QBD7ml8zLUmJ+93Q5NF0NocErnwkTkXVFNiX3/fpC6afS8Dhb/gz7R7eg== | ||||
| uuid@^9.0.0: | ||||
|   version "9.0.0" | ||||
|   resolved "https://registry.yarnpkg.com/uuid/-/uuid-9.0.0.tgz#592f550650024a38ceb0c562f2f6aa435761efb5" | ||||
|   integrity sha512-MXcSTerfPa4uqyzStbRoTgt5XIe3x5+42+q1sDuy3R5MDk66URdLMOZe5aPX/SQd+kuYAh0FdP/pO28IkQyTeg== | ||||
|  | ||||
| v8-compile-cache@^2.1.1, v8-compile-cache@^2.3.0: | ||||
|   version "2.3.0" | ||||
|   | ||||
		Reference in New Issue
	
	Block a user