Merge branch 'develop'
							
								
								
									
										13
									
								
								.eslintrc
									
										
									
									
									
								
							
							
						
						|  | @ -1,13 +0,0 @@ | ||||||
| { |  | ||||||
| 	"parserOptions": { |  | ||||||
| 		"parser": "@typescript-eslint/parser" |  | ||||||
| 	}, |  | ||||||
| 	"extends": [ |  | ||||||
| 		"eslint:recommended" |  | ||||||
| 	], |  | ||||||
| 	"rules": { |  | ||||||
| 		"no-console": 0, |  | ||||||
| 		"no-unused-vars": 0, |  | ||||||
| 		"no-empty": 0 |  | ||||||
| 	} |  | ||||||
| } |  | ||||||
							
								
								
									
										9
									
								
								.github/misskey/test.yml
									
										
									
									
										vendored
									
									
								
							
							
						
						|  | @ -1,12 +1,15 @@ | ||||||
| url: 'http://misskey.local' | url: 'http://misskey.local' | ||||||
| port: 8080 | 
 | ||||||
|  | # ローカルでテストするときにポートを被らないようにするためデフォルトのものとは変える(以下同じ) | ||||||
|  | port: 61812 | ||||||
|  | 
 | ||||||
| db: | db: | ||||||
|   host: localhost |   host: localhost | ||||||
|   port: 5432 |   port: 54312 | ||||||
|   db: test-misskey |   db: test-misskey | ||||||
|   user: postgres |   user: postgres | ||||||
|   pass: '' |   pass: '' | ||||||
| redis: | redis: | ||||||
|   host: localhost |   host: localhost | ||||||
|   port: 6379 |   port: 56312 | ||||||
| id: aid | id: aid | ||||||
|  |  | ||||||
							
								
								
									
										4
									
								
								.github/workflows/test.yml
									
										
									
									
										vendored
									
									
								
							
							
						
						|  | @ -41,7 +41,7 @@ jobs: | ||||||
|     - name: Check yarn.lock |     - name: Check yarn.lock | ||||||
|       run: git diff --exit-code yarn.lock |       run: git diff --exit-code yarn.lock | ||||||
|     - name: Copy Configure |     - name: Copy Configure | ||||||
|       run: cp test/test.yml .config |       run: cp .github/misskey/test.yml .config | ||||||
|     - name: Build |     - name: Build | ||||||
|       run: yarn build |       run: yarn build | ||||||
|     - name: Test |     - name: Test | ||||||
|  | @ -80,7 +80,7 @@ jobs: | ||||||
|     - name: Check yarn.lock |     - name: Check yarn.lock | ||||||
|       run: git diff --exit-code yarn.lock |       run: git diff --exit-code yarn.lock | ||||||
|     - name: Copy Configure |     - name: Copy Configure | ||||||
|       run: cp test/test.yml .config |       run: cp .github/misskey/test.yml .config | ||||||
|     - name: Build |     - name: Build | ||||||
|       run: yarn build |       run: yarn build | ||||||
|     - name: Test |     - name: Test | ||||||
|  |  | ||||||
							
								
								
									
										4
									
								
								.gitignore
									
										
									
									
										vendored
									
									
								
							
							
						
						|  | @ -6,7 +6,7 @@ | ||||||
| /.idea | /.idea | ||||||
| 
 | 
 | ||||||
| # Node.js | # Node.js | ||||||
| /node_modules | node_modules | ||||||
| report.*.json | report.*.json | ||||||
| 
 | 
 | ||||||
| # Cypress | # Cypress | ||||||
|  | @ -20,7 +20,7 @@ cypress/videos | ||||||
| 
 | 
 | ||||||
| # misskey | # misskey | ||||||
| /build | /build | ||||||
| /built | built | ||||||
| /data | /data | ||||||
| /.cache-loader | /.cache-loader | ||||||
| /db | /db | ||||||
|  |  | ||||||
|  | @ -1,5 +0,0 @@ | ||||||
| { |  | ||||||
| 	"ignoredFiles": [ |  | ||||||
| 		"test/resources/*" |  | ||||||
| 	] |  | ||||||
| } |  | ||||||
							
								
								
									
										21
									
								
								CHANGELOG.md
									
										
									
									
									
								
							
							
						
						|  | @ -7,6 +7,27 @@ | ||||||
| 
 | 
 | ||||||
| --> | --> | ||||||
| 
 | 
 | ||||||
|  | ## 12.96.0 (2021/11/13) | ||||||
|  | 
 | ||||||
|  | ### Improvements | ||||||
|  | - フォロー/フォロワーを非公開にできるように | ||||||
|  | - インスタンスプロフィールレンダリング ready | ||||||
|  | - 通知のリアクションアイコンをホバーで拡大できるように | ||||||
|  | - RenoteボタンをホバーでRenoteしたユーザー一覧を表示するように | ||||||
|  | - 返信の際にメンションを含めるように | ||||||
|  | - 通報があったときに管理者へEメールで通知されるように | ||||||
|  | - メールアドレスのバリデーションを強化 | ||||||
|  | 
 | ||||||
|  | ### Bugfixes | ||||||
|  | - アカウント削除処理があると高負荷になる問題を修正 | ||||||
|  | - クライアント: 長いメニューが画面からはみ出す問題を修正 | ||||||
|  | - クライアント: コントロールパネルのジョブキューに個々のジョブが表示されないのを修正 | ||||||
|  | - クライアント: fix missing i18n string | ||||||
|  | - fix html conversion issue with code blocks | ||||||
|  | 
 | ||||||
|  | ### Changes | ||||||
|  | - ノートにモバイルからの投稿か否かの情報を含めないように | ||||||
|  | 
 | ||||||
| ## 12.95.0 (2021/10/31) | ## 12.95.0 (2021/10/31) | ||||||
| 
 | 
 | ||||||
| ### Improvements | ### Improvements | ||||||
|  |  | ||||||
|  | @ -49,10 +49,6 @@ If your language is not listed in Crowdin, please open an issue. | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
| 
 | 
 | ||||||
| ## Documentation |  | ||||||
| * Documents for instance admins are located in [`/docs`](/docs). |  | ||||||
| * Documents for end users are located in [`/src/docs`](/src/docs). |  | ||||||
| 
 |  | ||||||
| ## Testing | ## Testing | ||||||
| - Test codes are located in [`/test`](/test). | - Test codes are located in [`/test`](/test). | ||||||
| 
 | 
 | ||||||
|  | @ -180,7 +176,7 @@ MongoDBは`null`で返してきてたので、その感覚で`if (x === null)` | ||||||
| 
 | 
 | ||||||
| ### Migration作成方法 | ### Migration作成方法 | ||||||
| ``` | ``` | ||||||
| npx ts-node ./node_modules/typeorm/cli.js migration:generate -n 変更の名前 | npx ts-node ./node_modules/typeorm/cli.js migration:generate -n 変更の名前 -o | ||||||
| ``` | ``` | ||||||
| 
 | 
 | ||||||
| 作成されたスクリプトは不必要な変更を含むため除去してください。 | 作成されたスクリプトは不必要な変更を含むため除去してください。 | ||||||
|  |  | ||||||
|  | @ -26,6 +26,10 @@ ENTRYPOINT ["/sbin/tini", "--"] | ||||||
| 
 | 
 | ||||||
| COPY --from=builder /misskey/node_modules ./node_modules | COPY --from=builder /misskey/node_modules ./node_modules | ||||||
| COPY --from=builder /misskey/built ./built | COPY --from=builder /misskey/built ./built | ||||||
|  | COPY --from=builder /misskey/packages/backend/node_modules ./packages/backend/node_modules | ||||||
|  | COPY --from=builder /misskey/packages/backend/built ./packages/backend/built | ||||||
|  | COPY --from=builder /misskey/packages/client/node_modules ./packages/client/node_modules | ||||||
|  | COPY --from=builder /misskey/packages/client/built ./packages/client/built | ||||||
| COPY . ./ | COPY . ./ | ||||||
| 
 | 
 | ||||||
| CMD ["npm", "run", "migrateandstart"] | CMD ["npm", "run", "migrateandstart"] | ||||||
|  |  | ||||||
|  | @ -2,6 +2,3 @@ files: | ||||||
|   - source: /locales/ja-JP.yml |   - source: /locales/ja-JP.yml | ||||||
|     translation: /locales/%locale%.yml |     translation: /locales/%locale%.yml | ||||||
|     update_option: update_as_unapproved |     update_option: update_as_unapproved | ||||||
|   - source: /src/docs/ja-JP/**/*.md |  | ||||||
|     translation: /src/docs/%locale%/**/%original_file_name% |  | ||||||
|     update_option: update_as_unapproved |  | ||||||
|  |  | ||||||
							
								
								
									
										62
									
								
								gulpfile.js
									
										
									
									
									
										Normal file
									
								
							
							
						
						|  | @ -0,0 +1,62 @@ | ||||||
|  | /** | ||||||
|  |  * Gulp tasks | ||||||
|  |  */ | ||||||
|  | 
 | ||||||
|  | const fs = require('fs'); | ||||||
|  | const gulp = require('gulp'); | ||||||
|  | const replace = require('gulp-replace'); | ||||||
|  | const terser = require('gulp-terser'); | ||||||
|  | const cssnano = require('gulp-cssnano'); | ||||||
|  | 
 | ||||||
|  | const locales = require('./locales'); | ||||||
|  | const meta = require('./package.json'); | ||||||
|  | 
 | ||||||
|  | gulp.task('copy:backend:views', () => | ||||||
|  | 	gulp.src('./packages/backend/src/server/web/views/**/*').pipe(gulp.dest('./packages/backend/built/server/web/views')) | ||||||
|  | ); | ||||||
|  | 
 | ||||||
|  | gulp.task('copy:client:fonts', () => | ||||||
|  | 	gulp.src('./packages/client/node_modules/three/examples/fonts/**/*').pipe(gulp.dest('./built/_client_dist_/fonts/')) | ||||||
|  | ); | ||||||
|  | 
 | ||||||
|  | gulp.task('copy:client:locales', cb => { | ||||||
|  | 	fs.mkdirSync('./built/_client_dist_/locales', { recursive: true }); | ||||||
|  | 
 | ||||||
|  | 	const v = { '_version_': meta.version }; | ||||||
|  | 
 | ||||||
|  | 	for (const [lang, locale] of Object.entries(locales)) { | ||||||
|  | 		fs.writeFileSync(`./built/_client_dist_/locales/${lang}.${meta.version}.json`, JSON.stringify({ ...locale, ...v }), 'utf-8'); | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	cb(); | ||||||
|  | }); | ||||||
|  | 
 | ||||||
|  | gulp.task('build:backend:script', () => { | ||||||
|  | 	return gulp.src(['./packages/backend/src/server/web/boot.js', './packages/backend/src/server/web/bios.js', './packages/backend/src/server/web/cli.js']) | ||||||
|  | 		.pipe(replace('VERSION', JSON.stringify(meta.version))) | ||||||
|  | 		.pipe(replace('LANGS', JSON.stringify(Object.keys(locales)))) | ||||||
|  | 		.pipe(terser({ | ||||||
|  | 			toplevel: true | ||||||
|  | 		})) | ||||||
|  | 		.pipe(gulp.dest('./packages/backend/built/server/web/')); | ||||||
|  | }); | ||||||
|  | 
 | ||||||
|  | gulp.task('build:backend:style', () => { | ||||||
|  | 	return gulp.src(['./packages/backend/src/server/web/style.css', './packages/backend/src/server/web/bios.css', './packages/backend/src/server/web/cli.css']) | ||||||
|  | 		.pipe(cssnano({ | ||||||
|  | 			zindex: false | ||||||
|  | 		})) | ||||||
|  | 		.pipe(gulp.dest('./packages/backend/built/server/web/')); | ||||||
|  | }); | ||||||
|  | 
 | ||||||
|  | gulp.task('build', gulp.parallel( | ||||||
|  | 	'copy:client:locales', 'copy:backend:views', 'build:backend:script', 'build:backend:style', 'copy:client:fonts' | ||||||
|  | )); | ||||||
|  | 
 | ||||||
|  | gulp.task('default', gulp.task('build')); | ||||||
|  | 
 | ||||||
|  | gulp.task('watch', () => { | ||||||
|  | 	gulp.watch([ | ||||||
|  | 		'./packages/**/*', | ||||||
|  | 	], { ignoreInitial: false }, gulp.task('build')); | ||||||
|  | }); | ||||||
							
								
								
									
										80
									
								
								gulpfile.ts
									
										
									
									
									
								
							
							
						
						|  | @ -1,80 +0,0 @@ | ||||||
| /** |  | ||||||
|  * Gulp tasks |  | ||||||
|  */ |  | ||||||
| 
 |  | ||||||
| import * as fs from 'fs'; |  | ||||||
| import * as gulp from 'gulp'; |  | ||||||
| import rimraf from 'rimraf'; |  | ||||||
| const replace = require('gulp-replace'); |  | ||||||
| const terser = require('gulp-terser'); |  | ||||||
| const cssnano = require('gulp-cssnano'); |  | ||||||
| 
 |  | ||||||
| const locales: { [x: string]: any } = require('./locales'); |  | ||||||
| const meta = require('./package.json'); |  | ||||||
| 
 |  | ||||||
| gulp.task('build:copy:views', () => |  | ||||||
| 	gulp.src('./src/server/web/views/**/*').pipe(gulp.dest('./built/server/web/views')) |  | ||||||
| ); |  | ||||||
| 
 |  | ||||||
| gulp.task('build:copy:fonts', () => |  | ||||||
| 	gulp.src('./node_modules/three/examples/fonts/**/*').pipe(gulp.dest('./built/assets/fonts/')) |  | ||||||
| ); |  | ||||||
| 
 |  | ||||||
| gulp.task('build:copy:locales', cb => { |  | ||||||
| 	fs.mkdirSync('./built/assets/locales', { recursive: true }); |  | ||||||
| 
 |  | ||||||
| 	const v = { '_version_': meta.version }; |  | ||||||
| 
 |  | ||||||
| 	for (const [lang, locale] of Object.entries(locales)) { |  | ||||||
| 		fs.writeFileSync(`./built/assets/locales/${lang}.${meta.version}.json`, JSON.stringify({ ...locale, ...v }), 'utf-8'); |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	cb(); |  | ||||||
| }); |  | ||||||
| 
 |  | ||||||
| gulp.task('build:client:script', () => { |  | ||||||
| 	return gulp.src(['./src/server/web/boot.js', './src/server/web/bios.js', './src/server/web/cli.js']) |  | ||||||
| 		.pipe(replace('VERSION', JSON.stringify(meta.version))) |  | ||||||
| 		.pipe(replace('LANGS', JSON.stringify(Object.keys(locales)))) |  | ||||||
| 		.pipe(terser({ |  | ||||||
| 			toplevel: true |  | ||||||
| 		})) |  | ||||||
| 		.pipe(gulp.dest('./built/server/web/')); |  | ||||||
| }); |  | ||||||
| 
 |  | ||||||
| gulp.task('build:client:style', () => { |  | ||||||
| 	return gulp.src(['./src/server/web/style.css', './src/server/web/bios.css', './src/server/web/cli.css']) |  | ||||||
| 		.pipe(cssnano({ |  | ||||||
| 			zindex: false |  | ||||||
| 		})) |  | ||||||
| 		.pipe(gulp.dest('./built/server/web/')); |  | ||||||
| }); |  | ||||||
| 
 |  | ||||||
| gulp.task('build:copy', gulp.parallel('build:copy:locales', 'build:copy:views', 'build:client:script', 'build:client:style', 'build:copy:fonts', () => |  | ||||||
| 	gulp.src([ |  | ||||||
| 		'./src/emojilist.json', |  | ||||||
| 		'./src/**/assets/**/*', |  | ||||||
| 		'!./src/client/assets/**/*' |  | ||||||
| 	]).pipe(gulp.dest('./built/')) |  | ||||||
| )); |  | ||||||
| 
 |  | ||||||
| gulp.task('clean', cb => |  | ||||||
| 	rimraf('./built', cb) |  | ||||||
| ); |  | ||||||
| 
 |  | ||||||
| gulp.task('cleanall', gulp.parallel('clean', cb => |  | ||||||
| 	rimraf('./node_modules', cb) |  | ||||||
| )); |  | ||||||
| 
 |  | ||||||
| gulp.task('build', gulp.parallel( |  | ||||||
| 	'build:copy', |  | ||||||
| )); |  | ||||||
| 
 |  | ||||||
| gulp.task('default', gulp.task('build')); |  | ||||||
| 
 |  | ||||||
| gulp.task('watch', () => { |  | ||||||
| 	gulp.watch([ |  | ||||||
| 		'./src/**/*', |  | ||||||
| 		'!./src/client/**/*' |  | ||||||
| 	], { ignoreInitial: false }, gulp.task('build')); |  | ||||||
| }); |  | ||||||
							
								
								
									
										17
									
								
								index.js
									
										
									
									
									
								
							
							
						
						|  | @ -1,17 +0,0 @@ | ||||||
| /* |  | ||||||
| import * as fs from 'fs'; |  | ||||||
| 
 |  | ||||||
| if (fs.existsSync('./built')) { |  | ||||||
| 	import('./built/index.js').then(built => built()); |  | ||||||
| } else { |  | ||||||
| 	console.log('Built code is not found. Probably an error occurred during a build or you just forgot to build.'); |  | ||||||
| } |  | ||||||
| */ |  | ||||||
| 
 |  | ||||||
| const fs = require('fs'); |  | ||||||
| 
 |  | ||||||
| if (fs.existsSync('./built')) { |  | ||||||
| 	require('./built').default(); |  | ||||||
| } else { |  | ||||||
| 	console.log('Built code is not found. Probably an error occurred during a build or you just forgot to build.'); |  | ||||||
| } |  | ||||||
|  | @ -797,6 +797,15 @@ unread: "Non lu" | ||||||
| filter: "Filtre" | filter: "Filtre" | ||||||
| controlPanel: "Panneau de contrôle" | controlPanel: "Panneau de contrôle" | ||||||
| manageAccounts: "Gérer les comptes" | manageAccounts: "Gérer les comptes" | ||||||
|  | classic: "Classique" | ||||||
|  | _emailUnavailable: | ||||||
|  |   format: "Le format de cette adresse de courriel est invalide" | ||||||
|  |   mx: "Ce serveur de courriels est invalide" | ||||||
|  |   smtp: "Ce serveur de courriels ne répond pas" | ||||||
|  | _ffVisibility: | ||||||
|  |   public: "Public" | ||||||
|  |   followers: "Visible uniquement pour les abonné·e·s" | ||||||
|  |   private: "Privé" | ||||||
| _signup: | _signup: | ||||||
|   almostThere: "Bientôt fini" |   almostThere: "Bientôt fini" | ||||||
|   emailAddressInfo: "Insérez votre adresse e-mail." |   emailAddressInfo: "Insérez votre adresse e-mail." | ||||||
|  | @ -808,13 +817,6 @@ _accountDelete: | ||||||
|   requestAccountDelete: "Demander la suppression de votre compte" |   requestAccountDelete: "Demander la suppression de votre compte" | ||||||
|   started: "La procédure de suppression a commencé." |   started: "La procédure de suppression a commencé." | ||||||
|   inProgress: "Suppression en cours" |   inProgress: "Suppression en cours" | ||||||
| _docs: |  | ||||||
|   continueReading: "Lire plus" |  | ||||||
|   features: "Fonctionnalités" |  | ||||||
|   generalTopics: "Sujets généraux" |  | ||||||
|   advancedTopics: "Sujets avancés" |  | ||||||
|   admin: "Gestion" |  | ||||||
|   translateWarn: "Ceci est une traduction dont le contenu peut différer du texte original." |  | ||||||
| _ad: | _ad: | ||||||
|   back: "Retour" |   back: "Retour" | ||||||
|   reduceFrequencyOfThisAd: "Voir cette publicité moins souvent" |   reduceFrequencyOfThisAd: "Voir cette publicité moins souvent" | ||||||
|  |  | ||||||
|  | @ -81,6 +81,8 @@ somethingHappened: "Terjadi kesalahan" | ||||||
| retry: "Coba lagi" | retry: "Coba lagi" | ||||||
| pageLoadError: "Gagal memuat halaman." | pageLoadError: "Gagal memuat halaman." | ||||||
| pageLoadErrorDescription: "Umumnya disebabkan jaringan atau tembolok perambah. Cobalah bersihkan tembolok peramban lalu tunggu sesaat sebelum mencoba kembali." | pageLoadErrorDescription: "Umumnya disebabkan jaringan atau tembolok perambah. Cobalah bersihkan tembolok peramban lalu tunggu sesaat sebelum mencoba kembali." | ||||||
|  | serverIsDead: "Tidak ada respon dari server. Mohon tunggu dan coba beberapa saat lagi." | ||||||
|  | youShouldUpgradeClient: "Untuk melihat halaman ini, mohon muat ulang untuk memutakhirkan klienmu." | ||||||
| enterListName: "Masukkan nama daftar" | enterListName: "Masukkan nama daftar" | ||||||
| privacy: "Privasi" | privacy: "Privasi" | ||||||
| makeFollowManuallyApprove: "Permintaan mengikuti membutuhkan persetujuan" | makeFollowManuallyApprove: "Permintaan mengikuti membutuhkan persetujuan" | ||||||
|  | @ -529,6 +531,8 @@ removeAllFollowing: "Tahan semua mengikuti" | ||||||
| removeAllFollowingDescription: "Batal mengikuti semua akun dari {host}. Mohon jalankan ini ketika instansi sudah tidak ada lagi." | removeAllFollowingDescription: "Batal mengikuti semua akun dari {host}. Mohon jalankan ini ketika instansi sudah tidak ada lagi." | ||||||
| userSuspended: "Pengguna ini telah dibekukan." | userSuspended: "Pengguna ini telah dibekukan." | ||||||
| userSilenced: "Pengguna ini telah dibungkam." | userSilenced: "Pengguna ini telah dibungkam." | ||||||
|  | yourAccountSuspendedTitle: "Akun ini dibekukan" | ||||||
|  | yourAccountSuspendedDescription: "Akun ini dibekukan karena melanggar ketentuan penggunaan layanan server atau semacamnya. Hubungi admin apabila ingin tahu alasan lebih lanjut. Mohon untuk tidak membuat akun baru." | ||||||
| menu: "Menu" | menu: "Menu" | ||||||
| divider: "Pembagi" | divider: "Pembagi" | ||||||
| addItem: "Tambahkan item" | addItem: "Tambahkan item" | ||||||
|  | @ -616,6 +620,8 @@ reportAbuse: "Laporkan" | ||||||
| reportAbuseOf: "Laporkan {name}" | reportAbuseOf: "Laporkan {name}" | ||||||
| fillAbuseReportDescription: "Mohon isi rincian laporan. Jika laporan ini mengenai catatan yang spesifik, mohon lampirkan serta URL catatan tersebut." | fillAbuseReportDescription: "Mohon isi rincian laporan. Jika laporan ini mengenai catatan yang spesifik, mohon lampirkan serta URL catatan tersebut." | ||||||
| abuseReported: "Laporan kamu telah dikirimkan. Terima kasih." | abuseReported: "Laporan kamu telah dikirimkan. Terima kasih." | ||||||
|  | reporteeOrigin: "Yang dilaporkan" | ||||||
|  | reporterOrigin: "Pelapor" | ||||||
| send: "Kirim" | send: "Kirim" | ||||||
| abuseMarkAsResolved: "Tandai laporan sebagai selesai" | abuseMarkAsResolved: "Tandai laporan sebagai selesai" | ||||||
| openInNewTab: "Buka di tab baru" | openInNewTab: "Buka di tab baru" | ||||||
|  | @ -762,6 +768,7 @@ middle: "Sedang" | ||||||
| low: "Rendah" | low: "Rendah" | ||||||
| emailNotConfiguredWarning: "Alamat surel tidak disetel." | emailNotConfiguredWarning: "Alamat surel tidak disetel." | ||||||
| ratio: "Rasio" | ratio: "Rasio" | ||||||
|  | previewNoteText: "Tampilkan pratinjau" | ||||||
| customCss: "Custom CSS" | customCss: "Custom CSS" | ||||||
| customCssWarn: "Pengaturan ini seharusnya digunakan jika kamu tahu cara kerjanya. Memasukkan nilai yang tidak tepat dapat menyebabkan klien tidak berfungsi semestinya." | customCssWarn: "Pengaturan ini seharusnya digunakan jika kamu tahu cara kerjanya. Memasukkan nilai yang tidak tepat dapat menyebabkan klien tidak berfungsi semestinya." | ||||||
| global: "Global" | global: "Global" | ||||||
|  | @ -779,8 +786,40 @@ translate: "Terjemahkan" | ||||||
| translatedFrom: "Terjemahkan dari {x}" | translatedFrom: "Terjemahkan dari {x}" | ||||||
| accountDeletionInProgress: "Penghapusan akun sedang dalam proses" | accountDeletionInProgress: "Penghapusan akun sedang dalam proses" | ||||||
| usernameInfo: "Nama yang mengidentifikasikan akun kamu dari yang lain pada server ini. Kamu dapat menggunakan alfabet (a~z, A~Z), digit (0~9) atau garis bawah (_). Username tidak dapat diubah setelahnya." | usernameInfo: "Nama yang mengidentifikasikan akun kamu dari yang lain pada server ini. Kamu dapat menggunakan alfabet (a~z, A~Z), digit (0~9) atau garis bawah (_). Username tidak dapat diubah setelahnya." | ||||||
|  | aiChanMode: "Mode Ai" | ||||||
| keepCw: "Biarkan Peringatan Konten" | keepCw: "Biarkan Peringatan Konten" | ||||||
|  | pubSub: "Akun Pub/Sub" | ||||||
|  | lastCommunication: "Komunikasi terakhir" | ||||||
|  | resolved: "Selesai" | ||||||
|  | unresolved: "Belum selesai" | ||||||
|  | itsOn: "Aktif" | ||||||
|  | itsOff: "Nonaktif" | ||||||
|  | emailRequiredForSignup: "Membutuhkan alamat surel untuk mendaftar" | ||||||
|  | unread: "Belum dibaca" | ||||||
|  | filter: "Saring" | ||||||
| controlPanel: "Panel kontrol" | controlPanel: "Panel kontrol" | ||||||
|  | manageAccounts: "Kelola Akun" | ||||||
|  | makeReactionsPublic: "Tampilkan riwayat reaksi ke publik" | ||||||
|  | makeReactionsPublicDescription: "Pengaturan ini akan membuat daftar dari semua reaksi masa lalu kamu ditampilkan secara publik." | ||||||
|  | classic: "Klasik" | ||||||
|  | muteThread: "Bisukan thread" | ||||||
|  | unmuteThread: "Suarakan thread" | ||||||
|  | ffVisibility: "Visibilitas Mengikuti/Pengikut" | ||||||
|  | ffVisibilityDescription: "Mengatur siapa yang dapat melihat pengikutmu dan yang kamu ikuti." | ||||||
|  | _emailUnavailable: | ||||||
|  |   used: "Alamat surel ini telah digunakan" | ||||||
|  |   format: "Format tidak valid." | ||||||
|  |   disposable: "Alamat surel temporer tidak dapat digunakan" | ||||||
|  |   mx: "Server alamat surel ini tidak valid" | ||||||
|  |   smtp: "Server alamat surel ini tidak merespon" | ||||||
|  | _ffVisibility: | ||||||
|  |   public: "Terbitkan" | ||||||
|  |   followers: "Tampil untuk pengikut saja" | ||||||
|  |   private: "Tersembunyi" | ||||||
|  | _signup: | ||||||
|  |   almostThere: "Hampir selesai" | ||||||
|  |   emailAddressInfo: "Mohon masukkan alamat surel kamu." | ||||||
|  |   emailSent: "Konfirmasi surel telah dikirimkan ke alamat surel kamu ({email}). Mohon klik tautan yang tercantum di dalamnya untuk menyelesaikan pembuatan akun." | ||||||
| _accountDelete: | _accountDelete: | ||||||
|   accountDelete: "Hapus akun" |   accountDelete: "Hapus akun" | ||||||
|   mayTakeTime: "Karena penghapusan akun merupakan proses yang berat dan intensif, kemungkinan dapat membutuhkan waktu untuk menyelesaikan tergantung daripada berapa banyak konten yang kamu buat dan berapa banyak berkas yang telah kamu unggah." |   mayTakeTime: "Karena penghapusan akun merupakan proses yang berat dan intensif, kemungkinan dapat membutuhkan waktu untuk menyelesaikan tergantung daripada berapa banyak konten yang kamu buat dan berapa banyak berkas yang telah kamu unggah." | ||||||
|  | @ -788,13 +827,6 @@ _accountDelete: | ||||||
|   requestAccountDelete: "Minta penghapusan akun" |   requestAccountDelete: "Minta penghapusan akun" | ||||||
|   started: "Penghapusan telah dimulai" |   started: "Penghapusan telah dimulai" | ||||||
|   inProgress: "Penghapusan sedang dalam proses" |   inProgress: "Penghapusan sedang dalam proses" | ||||||
| _docs: |  | ||||||
|   continueReading: "Baca lebih lanjut" |  | ||||||
|   features: "Fitur" |  | ||||||
|   generalTopics: "Topik umum" |  | ||||||
|   advancedTopics: "Topik tingkat lanjut" |  | ||||||
|   admin: "Manajemen" |  | ||||||
|   translateWarn: "Ini merupakan dokumen terjemahan. Konten di dalamnya kemungkinan dapat berbeda dari yang aslinya." |  | ||||||
| _ad: | _ad: | ||||||
|   back: "Kembali" |   back: "Kembali" | ||||||
|   reduceFrequencyOfThisAd: "Tampilkan iklan ini lebih sedikit" |   reduceFrequencyOfThisAd: "Tampilkan iklan ini lebih sedikit" | ||||||
|  | @ -895,6 +927,8 @@ _mfm: | ||||||
|   fontDescription: "Setel font yang ditampilkan untuk konten." |   fontDescription: "Setel font yang ditampilkan untuk konten." | ||||||
|   rainbow: "Pelangi" |   rainbow: "Pelangi" | ||||||
|   rainbowDescription: "Membuat konten muncul dalam warna pelangi." |   rainbowDescription: "Membuat konten muncul dalam warna pelangi." | ||||||
|  |   sparkle: "Kelap-kelip" | ||||||
|  |   sparkleDescription: "Memberikan konten efek partikel kelap-kelip." | ||||||
| _reversi: | _reversi: | ||||||
|   reversi: "Reversi" |   reversi: "Reversi" | ||||||
|   gameSettings: "Pengaturan permainan" |   gameSettings: "Pengaturan permainan" | ||||||
|  | @ -1121,6 +1155,10 @@ _permissions: | ||||||
|   "write:user-groups": "Sunting atau hapus grup pengguna" |   "write:user-groups": "Sunting atau hapus grup pengguna" | ||||||
|   "read:channels": "Lihat saluran" |   "read:channels": "Lihat saluran" | ||||||
|   "write:channels": "Sunting saluran" |   "write:channels": "Sunting saluran" | ||||||
|  |   "read:gallery": "Lihat galeri" | ||||||
|  |   "write:gallery": "Sunting galeri" | ||||||
|  |   "read:gallery-likes": "Lihat daftar postingan galeri yang disukai" | ||||||
|  |   "write:gallery-likes": "Sunting daftar postingan galeri yang disukai" | ||||||
| _auth: | _auth: | ||||||
|   shareAccess: "Apakah kamu ingin mengijinkan \"{name}\" untuk mengakses akun ini?" |   shareAccess: "Apakah kamu ingin mengijinkan \"{name}\" untuk mengakses akun ini?" | ||||||
|   shareAccessAsk: "Apakah kamu ingin mengijinkan aplikasi ini untuk mengakses akun kamu?" |   shareAccessAsk: "Apakah kamu ingin mengijinkan aplikasi ini untuk mengakses akun kamu?" | ||||||
|  |  | ||||||
|  | @ -19,9 +19,11 @@ const languages = [ | ||||||
| 	'da-DK', | 	'da-DK', | ||||||
| 	'de-DE', | 	'de-DE', | ||||||
| 	'en-US', | 	'en-US', | ||||||
|  | 	'eo-UY', | ||||||
| 	'es-ES', | 	'es-ES', | ||||||
| 	'fr-FR', | 	'fr-FR', | ||||||
| 	'id-ID', | 	'id-ID', | ||||||
|  | 	'it-IT', | ||||||
| 	'ja-JP', | 	'ja-JP', | ||||||
| 	'ja-KS', | 	'ja-KS', | ||||||
| 	'kab-KAB', | 	'kab-KAB', | ||||||
|  |  | ||||||
|  | @ -620,6 +620,8 @@ reportAbuse: "通報" | ||||||
| reportAbuseOf: "{name}を通報する" | reportAbuseOf: "{name}を通報する" | ||||||
| fillAbuseReportDescription: "通報理由の詳細を記入してください。対象のノートがある場合はそのURLも記入してください。" | fillAbuseReportDescription: "通報理由の詳細を記入してください。対象のノートがある場合はそのURLも記入してください。" | ||||||
| abuseReported: "内容が送信されました。ご報告ありがとうございました。" | abuseReported: "内容が送信されました。ご報告ありがとうございました。" | ||||||
|  | reporteeOrigin: "通報先" | ||||||
|  | reporterOrigin: "通報元" | ||||||
| send: "送信" | send: "送信" | ||||||
| abuseMarkAsResolved: "対応済みにする" | abuseMarkAsResolved: "対応済みにする" | ||||||
| openInNewTab: "新しいタブで開く" | openInNewTab: "新しいタブで開く" | ||||||
|  | @ -802,6 +804,20 @@ makeReactionsPublicDescription: "あなたがしたリアクション一覧を | ||||||
| classic: "クラシック" | classic: "クラシック" | ||||||
| muteThread: "スレッドをミュート" | muteThread: "スレッドをミュート" | ||||||
| unmuteThread: "スレッドのミュートを解除" | unmuteThread: "スレッドのミュートを解除" | ||||||
|  | ffVisibility: "つながりの公開範囲" | ||||||
|  | ffVisibilityDescription: "自分のフォロー/フォロワー情報の公開範囲を設定できます。" | ||||||
|  | 
 | ||||||
|  | _emailUnavailable: | ||||||
|  |   used: "既に使用されています" | ||||||
|  |   format: "形式が正しくありません" | ||||||
|  |   disposable: "恒久的に使用可能なアドレスではありません" | ||||||
|  |   mx: "正しいメールサーバーではありません" | ||||||
|  |   smtp: "メールサーバーが応答しません" | ||||||
|  | 
 | ||||||
|  | _ffVisibility: | ||||||
|  |   public: "公開" | ||||||
|  |   followers: "フォロワーだけに公開" | ||||||
|  |   private: "非公開" | ||||||
| 
 | 
 | ||||||
| _signup: | _signup: | ||||||
|   almostThere: "ほとんど完了です" |   almostThere: "ほとんど完了です" | ||||||
|  | @ -816,14 +832,6 @@ _accountDelete: | ||||||
|   started: "削除処理が開始されました。" |   started: "削除処理が開始されました。" | ||||||
|   inProgress: "削除が進行中" |   inProgress: "削除が進行中" | ||||||
| 
 | 
 | ||||||
| _docs:  |  | ||||||
|   continueReading: "続きを読む" |  | ||||||
|   features: "機能" |  | ||||||
|   generalTopics: "一般的なトピック" |  | ||||||
|   advancedTopics: "高度なトピック" |  | ||||||
|   admin: "管理" |  | ||||||
|   translateWarn: "このドキュメントは翻訳されたものです。オリジナルとは内容が異なる場合があります。" |  | ||||||
| 
 |  | ||||||
| _ad: | _ad: | ||||||
|   back: "戻る" |   back: "戻る" | ||||||
|   reduceFrequencyOfThisAd: "この広告の表示頻度を下げる" |   reduceFrequencyOfThisAd: "この広告の表示頻度を下げる" | ||||||
|  |  | ||||||
							
								
								
									
										62
									
								
								locales/tr-TR.yml
									
										
									
									
									
										Normal file
									
								
							
							
						
						|  | @ -0,0 +1,62 @@ | ||||||
|  | --- | ||||||
|  | _lang_: "Türkçe" | ||||||
|  | introMisskey: "Açık kaynaklı bir dağıtılmış mikroblog hizmeti olan Misskey'e hoş geldiniz.\nMisskey, neler olup bittiğini paylaşmak ve herkese sizden bahsetmek için \"notlar\" oluşturmanıza olanak tanıyan, açık kaynaklı, dağıtılmış bir mikroblog hizmetidir.\nHerkesin notlarına kendi tepkilerinizi hızlıca eklemek için \"Tepkiler\" özelliğini de kullanabilirsiniz👍.\nYeni bir dünyayı keşfedin🚀." | ||||||
|  | monthAndDay: "{month}Ay {day}Gün" | ||||||
|  | search: "Arama" | ||||||
|  | notifications: "Bildirim" | ||||||
|  | username: "Kullanıcı Adı" | ||||||
|  | password: "Şifre" | ||||||
|  | forgotPassword: "şifremi unuttum" | ||||||
|  | ok: "TAMAM" | ||||||
|  | gotIt: "Anladım" | ||||||
|  | cancel: "İptal" | ||||||
|  | enterUsername: "Kullanıcı adınızı giriniz" | ||||||
|  | noNotes: "Notlar mevcut değil." | ||||||
|  | noNotifications: "Bildirim bulunmuyor" | ||||||
|  | settings: "Ayarlar" | ||||||
|  | basicSettings: "Temel Ayarlar" | ||||||
|  | otherSettings: "Diğer Ayarlar" | ||||||
|  | openInWindow: "Bir pencere ile aç" | ||||||
|  | profile: "Profil" | ||||||
|  | timeline: "Zaman çizelgesi" | ||||||
|  | noAccountDescription: "Bu kullanıcı henüz biyografisini yazmadı" | ||||||
|  | login: "Giriş Yap " | ||||||
|  | logout: "Çıkış Yap" | ||||||
|  | signup: "Kayıt Ol" | ||||||
|  | uploading: "Yükleniyor" | ||||||
|  | users: "Kullanıcı" | ||||||
|  | addUser: "Kullanıcı Ekle" | ||||||
|  | favorite: "Favoriler" | ||||||
|  | favorites: "Favoriler" | ||||||
|  | unfavorite: "Favorilerden Kaldır" | ||||||
|  | favorited: "Favorilerime eklendi." | ||||||
|  | alreadyFavorited: "Zaten favorilerinizde kayıtlı." | ||||||
|  | pin: "Sabitlenmiş" | ||||||
|  | unpin: "Sabitlemeyi kaldır" | ||||||
|  | copyContent: "İçeriği kopyala" | ||||||
|  | copyLink: "Bağlantıyı Kopyala" | ||||||
|  | delete: "Sil" | ||||||
|  | deleteAndEdit: "Sil ve yeniden düzenle" | ||||||
|  | deleteAndEditConfirm: "Bu notu silip yeniden düzenlemek istiyor musunuz? Bu nota ilişkin tüm Tepkiler, Yeniden Notlar ve Yanıtlar da silinecektir." | ||||||
|  | addToList: "Listeye ekle" | ||||||
|  | sendMessage: "Mesaj Gönder" | ||||||
|  | copyUsername: "Kullanıcı Adını Kopyala" | ||||||
|  | searchUser: "Kullanıcıları ara" | ||||||
|  | pinned: "Sabitlenmiş" | ||||||
|  | remove: "Sil" | ||||||
|  | smtpUser: "Kullanıcı Adı" | ||||||
|  | smtpPass: "Şifre" | ||||||
|  | user: "Kullanıcı" | ||||||
|  | _mfm: | ||||||
|  |   search: "Arama" | ||||||
|  | _sfx: | ||||||
|  |   notification: "Bildirim" | ||||||
|  | _widgets: | ||||||
|  |   notifications: "Bildirim" | ||||||
|  |   timeline: "Zaman çizelgesi" | ||||||
|  | _profile: | ||||||
|  |   username: "Kullanıcı Adı" | ||||||
|  | _deck: | ||||||
|  |   _columns: | ||||||
|  |     notifications: "Bildirim" | ||||||
|  |     tl: "Zaman çizelgesi" | ||||||
|  | @ -1,13 +0,0 @@ | ||||||
| import {MigrationInterface, QueryRunner} from "typeorm"; |  | ||||||
| 
 |  | ||||||
| export class PinnedUsers1557476068003 implements MigrationInterface { |  | ||||||
| 
 |  | ||||||
|     public async up(queryRunner: QueryRunner): Promise<any> { |  | ||||||
|         await queryRunner.query(`ALTER TABLE "meta" ADD "pinnedUsers" character varying(256) array NOT NULL DEFAULT '{}'::varchar[]`); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     public async down(queryRunner: QueryRunner): Promise<any> { |  | ||||||
|         await queryRunner.query(`ALTER TABLE "meta" DROP COLUMN "pinnedUsers"`); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
| } |  | ||||||
|  | @ -1,13 +0,0 @@ | ||||||
| import {MigrationInterface, QueryRunner} from "typeorm"; |  | ||||||
| 
 |  | ||||||
| export class UserListJoining1558266512381 implements MigrationInterface { |  | ||||||
| 
 |  | ||||||
|     public async up(queryRunner: QueryRunner): Promise<any> { |  | ||||||
|         await queryRunner.query(`CREATE UNIQUE INDEX "IDX_90f7da835e4c10aca6853621e1" ON "user_list_joining" ("userId", "userListId") `); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     public async down(queryRunner: QueryRunner): Promise<any> { |  | ||||||
|         await queryRunner.query(`DROP INDEX "IDX_90f7da835e4c10aca6853621e1"`); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
| } |  | ||||||
|  | @ -1,13 +0,0 @@ | ||||||
| import {MigrationInterface, QueryRunner} from "typeorm"; |  | ||||||
| 
 |  | ||||||
| export class PasswordLessLogin1562422242907 implements MigrationInterface { |  | ||||||
| 
 |  | ||||||
| 	public async up(queryRunner: QueryRunner): Promise<any> { |  | ||||||
| 		await queryRunner.query(`ALTER TABLE "user_profile" ADD COLUMN "usePasswordLessLogin" boolean DEFAULT false NOT NULL`); |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	public async down(queryRunner: QueryRunner): Promise<any> { |  | ||||||
| 		await queryRunner.query(`ALTER TABLE "user_profile" DROP COLUMN "usePasswordLessLogin"`); |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| } |  | ||||||
|  | @ -1,13 +0,0 @@ | ||||||
| import {MigrationInterface, QueryRunner} from "typeorm"; |  | ||||||
| 
 |  | ||||||
| export class PageTitleHideOption1562448332510 implements MigrationInterface { |  | ||||||
| 
 |  | ||||||
|     public async up(queryRunner: QueryRunner): Promise<any> { |  | ||||||
|         await queryRunner.query(`ALTER TABLE "page" ADD "hideTitleWhenPinned" boolean NOT NULL DEFAULT false`); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     public async down(queryRunner: QueryRunner): Promise<any> { |  | ||||||
|         await queryRunner.query(`ALTER TABLE "page" DROP COLUMN "hideTitleWhenPinned"`); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
| } |  | ||||||
|  | @ -1,13 +0,0 @@ | ||||||
| import {MigrationInterface, QueryRunner} from "typeorm"; |  | ||||||
| 
 |  | ||||||
| export class room1565634203341 implements MigrationInterface { |  | ||||||
| 
 |  | ||||||
|     public async up(queryRunner: QueryRunner): Promise<any> { |  | ||||||
|         await queryRunner.query(`ALTER TABLE "user_profile" ADD "room" jsonb NOT NULL DEFAULT '{}'`); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     public async down(queryRunner: QueryRunner): Promise<any> { |  | ||||||
|         await queryRunner.query(`ALTER TABLE "user_profile" DROP COLUMN "room"`); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
| } |  | ||||||
|  | @ -1,13 +0,0 @@ | ||||||
| import {MigrationInterface, QueryRunner} from "typeorm"; |  | ||||||
| 
 |  | ||||||
| export class CustomEmojiCategory1571220798684 implements MigrationInterface { |  | ||||||
| 
 |  | ||||||
|     public async up(queryRunner: QueryRunner): Promise<any> { |  | ||||||
|         await queryRunner.query(`ALTER TABLE "emoji" ADD "category" character varying(128)`, undefined); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     public async down(queryRunner: QueryRunner): Promise<any> { |  | ||||||
|         await queryRunner.query(`ALTER TABLE "emoji" DROP COLUMN "category"`, undefined); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
| } |  | ||||||
|  | @ -1,14 +0,0 @@ | ||||||
| import {MigrationInterface, QueryRunner} from "typeorm"; |  | ||||||
| 
 |  | ||||||
| export class TalkFederationId1576269851876 implements MigrationInterface { |  | ||||||
|     name = 'TalkFederationId1576269851876' |  | ||||||
| 
 |  | ||||||
|     public async up(queryRunner: QueryRunner): Promise<any> { |  | ||||||
|         await queryRunner.query(`ALTER TABLE "messaging_message" ADD "uri" character varying(512)`, undefined); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     public async down(queryRunner: QueryRunner): Promise<any> { |  | ||||||
|         await queryRunner.query(`ALTER TABLE "messaging_message" DROP COLUMN "uri"`, undefined); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
| } |  | ||||||
|  | @ -1,14 +0,0 @@ | ||||||
| import {MigrationInterface, QueryRunner} from "typeorm"; |  | ||||||
| 
 |  | ||||||
| export class ProxyRemoteFiles1576869585998 implements MigrationInterface { |  | ||||||
|     name = 'ProxyRemoteFiles1576869585998' |  | ||||||
| 
 |  | ||||||
|     public async up(queryRunner: QueryRunner): Promise<any> { |  | ||||||
|         await queryRunner.query(`ALTER TABLE "meta" ADD "proxyRemoteFiles" boolean NOT NULL DEFAULT false`, undefined); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     public async down(queryRunner: QueryRunner): Promise<any> { |  | ||||||
|         await queryRunner.query(`ALTER TABLE "meta" DROP COLUMN "proxyRemoteFiles"`, undefined); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
| } |  | ||||||
|  | @ -1,14 +0,0 @@ | ||||||
| import {MigrationInterface, QueryRunner} from "typeorm"; |  | ||||||
| 
 |  | ||||||
| export class v1221579270193251 implements MigrationInterface { |  | ||||||
|     name = 'v1221579270193251' |  | ||||||
| 
 |  | ||||||
|     public async up(queryRunner: QueryRunner): Promise<any> { |  | ||||||
|         await queryRunner.query(`ALTER TABLE "announcement_read" ADD "createdAt" TIMESTAMP WITH TIME ZONE NOT NULL`, undefined); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     public async down(queryRunner: QueryRunner): Promise<any> { |  | ||||||
|         await queryRunner.query(`ALTER TABLE "announcement_read" DROP COLUMN "createdAt"`, undefined); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
| } |  | ||||||
|  | @ -1,14 +0,0 @@ | ||||||
| import {MigrationInterface, QueryRunner} from "typeorm"; |  | ||||||
| 
 |  | ||||||
| export class v1231579282808087 implements MigrationInterface { |  | ||||||
|     name = 'v1231579282808087' |  | ||||||
| 
 |  | ||||||
|     public async up(queryRunner: QueryRunner): Promise<any> { |  | ||||||
|         await queryRunner.query(`ALTER TABLE "announcement" ADD "updatedAt" TIMESTAMP WITH TIME ZONE`, undefined); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     public async down(queryRunner: QueryRunner): Promise<any> { |  | ||||||
|         await queryRunner.query(`ALTER TABLE "announcement" DROP COLUMN "updatedAt"`, undefined); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
| } |  | ||||||
|  | @ -1,14 +0,0 @@ | ||||||
| import {MigrationInterface, QueryRunner} from "typeorm"; |  | ||||||
| 
 |  | ||||||
| export class v1291580154400017 implements MigrationInterface { |  | ||||||
|     name = 'v1291580154400017' |  | ||||||
| 
 |  | ||||||
|     public async up(queryRunner: QueryRunner): Promise<any> { |  | ||||||
|         await queryRunner.query(`ALTER TABLE "antenna" ADD "withReplies" boolean NOT NULL DEFAULT false`, undefined); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     public async down(queryRunner: QueryRunner): Promise<any> { |  | ||||||
|         await queryRunner.query(`ALTER TABLE "antenna" DROP COLUMN "withReplies"`, undefined); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
| } |  | ||||||
|  | @ -1,14 +0,0 @@ | ||||||
| import {MigrationInterface, QueryRunner} from "typeorm"; |  | ||||||
| 
 |  | ||||||
| export class v12131580543501339 implements MigrationInterface { |  | ||||||
|     name = 'v12131580543501339' |  | ||||||
| 
 |  | ||||||
|     public async up(queryRunner: QueryRunner): Promise<any> { |  | ||||||
|         await queryRunner.query(`CREATE INDEX "IDX_NOTE_TAGS" ON "note" USING gin ("tags")`, undefined); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     public async down(queryRunner: QueryRunner): Promise<any> { |  | ||||||
|         await queryRunner.query(`DROP INDEX "IDX_NOTE_TAGS"`, undefined); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
| } |  | ||||||
|  | @ -1,14 +0,0 @@ | ||||||
| import {MigrationInterface, QueryRunner} from "typeorm"; |  | ||||||
| 
 |  | ||||||
| export class driveUserFolderIdIndex1581708415836 implements MigrationInterface { |  | ||||||
|     name = 'driveUserFolderIdIndex1581708415836' |  | ||||||
| 
 |  | ||||||
|     public async up(queryRunner: QueryRunner): Promise<any> { |  | ||||||
|         await queryRunner.query(`CREATE INDEX "IDX_55720b33a61a7c806a8215b825" ON "drive_file" ("userId", "folderId", "id") `, undefined); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     public async down(queryRunner: QueryRunner): Promise<any> { |  | ||||||
|         await queryRunner.query(`DROP INDEX "IDX_55720b33a61a7c806a8215b825"`, undefined); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
| } |  | ||||||
|  | @ -1,14 +0,0 @@ | ||||||
| import {MigrationInterface, QueryRunner} from "typeorm"; |  | ||||||
| 
 |  | ||||||
| export class featuredInjecttion1582019042083 implements MigrationInterface { |  | ||||||
|     name = 'featuredInjecttion1582019042083' |  | ||||||
| 
 |  | ||||||
|     public async up(queryRunner: QueryRunner): Promise<any> { |  | ||||||
|         await queryRunner.query(`ALTER TABLE "user_profile" ADD "injectFeaturedNote" boolean NOT NULL DEFAULT true`, undefined); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     public async down(queryRunner: QueryRunner): Promise<any> { |  | ||||||
|         await queryRunner.query(`ALTER TABLE "user_profile" DROP COLUMN "injectFeaturedNote"`, undefined); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
| } |  | ||||||
|  | @ -1,14 +0,0 @@ | ||||||
| import {MigrationInterface, QueryRunner} from "typeorm"; |  | ||||||
| 
 |  | ||||||
| export class antennaExclude1582210532752 implements MigrationInterface { |  | ||||||
|     name = 'antennaExclude1582210532752' |  | ||||||
| 
 |  | ||||||
|     public async up(queryRunner: QueryRunner): Promise<any> { |  | ||||||
|         await queryRunner.query(`ALTER TABLE "antenna" ADD "excludeKeywords" jsonb NOT NULL DEFAULT '[]'`, undefined); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     public async down(queryRunner: QueryRunner): Promise<any> { |  | ||||||
|         await queryRunner.query(`ALTER TABLE "antenna" DROP COLUMN "excludeKeywords"`, undefined); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
| } |  | ||||||
|  | @ -1,14 +0,0 @@ | ||||||
| import {MigrationInterface, QueryRunner} from "typeorm"; |  | ||||||
| 
 |  | ||||||
| export class noteReactionLength1582875306439 implements MigrationInterface { |  | ||||||
|     name = 'noteReactionLength1582875306439' |  | ||||||
| 
 |  | ||||||
|     public async up(queryRunner: QueryRunner): Promise<any> { |  | ||||||
|         await queryRunner.query(`ALTER TABLE "note_reaction" ALTER COLUMN "reaction" TYPE character varying(130)`, undefined); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     public async down(queryRunner: QueryRunner): Promise<any> { |  | ||||||
|         await queryRunner.query(`ALTER TABLE "note_reaction" ALTER COLUMN "reaction" TYPE character varying(128)`, undefined); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
| } |  | ||||||
|  | @ -1,15 +0,0 @@ | ||||||
| /* tslint:disable:quotemark class-name indent */ |  | ||||||
| import {MigrationInterface, QueryRunner} from "typeorm"; |  | ||||||
| 
 |  | ||||||
| export class apUrl1585772678853 implements MigrationInterface { |  | ||||||
|     name = 'apUrl1585772678853' |  | ||||||
| 
 |  | ||||||
|     public async up(queryRunner: QueryRunner): Promise<any> { |  | ||||||
|         await queryRunner.query(`ALTER TABLE "note" ADD "url" character varying(512)`, undefined); |  | ||||||
|      } |  | ||||||
| 
 |  | ||||||
|     public async down(queryRunner: QueryRunner): Promise<any> { |  | ||||||
|         await queryRunner.query(`ALTER TABLE "note" DROP COLUMN "url"`, undefined); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
| } |  | ||||||
|  | @ -1,14 +0,0 @@ | ||||||
| import {MigrationInterface, QueryRunner} from 'typeorm'; |  | ||||||
| 
 |  | ||||||
| export class AddObjectStorageUseProxy1586624197029 implements MigrationInterface { |  | ||||||
| 		name = 'AddObjectStorageUseProxy1586624197029' |  | ||||||
| 
 |  | ||||||
| 		public async up(queryRunner: QueryRunner): Promise<void> { |  | ||||||
| 				await queryRunner.query(`ALTER TABLE "meta" ADD "objectStorageUseProxy" boolean NOT NULL DEFAULT true`, undefined); |  | ||||||
| 		} |  | ||||||
| 
 |  | ||||||
| 		public async down(queryRunner: QueryRunner): Promise<void> { |  | ||||||
| 				await queryRunner.query(`ALTER TABLE "meta" DROP COLUMN "objectStorageUseProxy"`, undefined); |  | ||||||
| 		} |  | ||||||
| 
 |  | ||||||
| } |  | ||||||
|  | @ -1,12 +0,0 @@ | ||||||
| import {MigrationInterface, QueryRunner} from "typeorm"; |  | ||||||
| 
 |  | ||||||
| export class remoteReaction1586641139527 implements MigrationInterface { |  | ||||||
|     name = 'remoteReaction1586641139527' |  | ||||||
|     public async up(queryRunner: QueryRunner): Promise<any> { |  | ||||||
|       await queryRunner.query(`ALTER TABLE "note_reaction" ALTER COLUMN "reaction" TYPE character varying(260)`, undefined); |  | ||||||
|   } |  | ||||||
| 
 |  | ||||||
|   public async down(queryRunner: QueryRunner): Promise<any> { |  | ||||||
|       await queryRunner.query(`ALTER TABLE "note_reaction" ALTER COLUMN "reaction" TYPE character varying(130)`, undefined); |  | ||||||
|   } |  | ||||||
| } |  | ||||||
|  | @ -1,14 +0,0 @@ | ||||||
| import {MigrationInterface, QueryRunner} from "typeorm"; |  | ||||||
| 
 |  | ||||||
| export class pageAiScript1586708940386 implements MigrationInterface { |  | ||||||
|     name = 'pageAiScript1586708940386' |  | ||||||
| 
 |  | ||||||
|     public async up(queryRunner: QueryRunner): Promise<void> { |  | ||||||
|         await queryRunner.query(`ALTER TABLE "page" ADD "script" character varying(16384) NOT NULL DEFAULT ''`, undefined); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     public async down(queryRunner: QueryRunner): Promise<void> { |  | ||||||
|         await queryRunner.query(`ALTER TABLE "page" DROP COLUMN "script"`, undefined); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
| } |  | ||||||
|  | @ -1,14 +0,0 @@ | ||||||
| import {MigrationInterface, QueryRunner} from "typeorm"; |  | ||||||
| 
 |  | ||||||
| export class blurhash1595075960584 implements MigrationInterface { |  | ||||||
|     name = 'blurhash1595075960584' |  | ||||||
| 
 |  | ||||||
|     public async up(queryRunner: QueryRunner): Promise<void> { |  | ||||||
|         await queryRunner.query(`ALTER TABLE "drive_file" ADD "blurhash" character varying(128)`); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     public async down(queryRunner: QueryRunner): Promise<void> { |  | ||||||
|         await queryRunner.query(`ALTER TABLE "drive_file" DROP COLUMN "blurhash"`); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
| } |  | ||||||
|  | @ -1,14 +0,0 @@ | ||||||
| import {MigrationInterface, QueryRunner} from "typeorm"; |  | ||||||
| 
 |  | ||||||
| export class instanceIconUrl1595676934834 implements MigrationInterface { |  | ||||||
|     name = 'instanceIconUrl1595676934834' |  | ||||||
| 
 |  | ||||||
|     public async up(queryRunner: QueryRunner): Promise<void> { |  | ||||||
|         await queryRunner.query(`ALTER TABLE "instance" ADD "iconUrl" character varying(256) DEFAULT null`); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     public async down(queryRunner: QueryRunner): Promise<void> { |  | ||||||
|         await queryRunner.query(`ALTER TABLE "instance" DROP COLUMN "iconUrl"`); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
| } |  | ||||||
|  | @ -1,14 +0,0 @@ | ||||||
| import {MigrationInterface, QueryRunner} from "typeorm"; |  | ||||||
| 
 |  | ||||||
| export class channel21596786425167 implements MigrationInterface { |  | ||||||
|     name = 'channel21596786425167' |  | ||||||
| 
 |  | ||||||
|     public async up(queryRunner: QueryRunner): Promise<void> { |  | ||||||
|         await queryRunner.query(`ALTER TABLE "channel_following" ADD "readCursor" TIMESTAMP WITH TIME ZONE NOT NULL`); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     public async down(queryRunner: QueryRunner): Promise<void> { |  | ||||||
|         await queryRunner.query(`ALTER TABLE "channel_following" DROP COLUMN "readCursor"`); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
| } |  | ||||||
|  | @ -1,14 +0,0 @@ | ||||||
| import {MigrationInterface, QueryRunner} from "typeorm"; |  | ||||||
| 
 |  | ||||||
| export class objectStorageSetPublicRead1597230137744 implements MigrationInterface { |  | ||||||
|     name = 'objectStorageSetPublicRead1597230137744' |  | ||||||
| 
 |  | ||||||
|     public async up(queryRunner: QueryRunner): Promise<void> { |  | ||||||
|         await queryRunner.query(`ALTER TABLE "meta" ADD "objectStorageSetPublicRead" boolean NOT NULL DEFAULT false`); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     public async down(queryRunner: QueryRunner): Promise<void> { |  | ||||||
|         await queryRunner.query(`ALTER TABLE "meta" DROP COLUMN "objectStorageSetPublicRead"`); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
| } |  | ||||||
|  | @ -1,14 +0,0 @@ | ||||||
| import {MigrationInterface, QueryRunner} from "typeorm"; |  | ||||||
| 
 |  | ||||||
| export class addSensitiveIndex1597385880794 implements MigrationInterface { |  | ||||||
|     name = 'addSensitiveIndex1597385880794' |  | ||||||
| 
 |  | ||||||
|     public async up(queryRunner: QueryRunner): Promise<void> { |  | ||||||
|         await queryRunner.query(`CREATE INDEX "IDX_a7eba67f8b3fa27271e85d2e26" ON "drive_file" ("isSensitive") `); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     public async down(queryRunner: QueryRunner): Promise<void> { |  | ||||||
|         await queryRunner.query(`DROP INDEX "IDX_a7eba67f8b3fa27271e85d2e26"`); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
| } |  | ||||||
|  | @ -1,16 +0,0 @@ | ||||||
| import {MigrationInterface, QueryRunner} from "typeorm"; |  | ||||||
| 
 |  | ||||||
| export class ChannelNoteIdDescIndex1597893996136 implements MigrationInterface { |  | ||||||
|     name = 'ChannelNoteIdDescIndex1597893996136' |  | ||||||
| 
 |  | ||||||
|     public async up(queryRunner: QueryRunner): Promise<void> { |  | ||||||
| 				await queryRunner.query(`DROP INDEX "IDX_f22169eb10657bded6d875ac8f"`); |  | ||||||
| 				await queryRunner.query(`CREATE INDEX "IDX_note_on_channelId_and_id_desc" ON "note" ("channelId", "id" desc)`); |  | ||||||
| 		} |  | ||||||
| 
 |  | ||||||
|     public async down(queryRunner: QueryRunner): Promise<void> { |  | ||||||
| 				await queryRunner.query(`DROP INDEX "IDX_note_on_channelId_and_id_desc"`); |  | ||||||
|         await queryRunner.query(`CREATE INDEX "IDX_f22169eb10657bded6d875ac8f" ON "note" ("channelId") `); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
| } |  | ||||||
|  | @ -1,14 +0,0 @@ | ||||||
| import {MigrationInterface, QueryRunner} from "typeorm"; |  | ||||||
| 
 |  | ||||||
| export class instanceThemeColor1603776877564 implements MigrationInterface { |  | ||||||
|     name = 'instanceThemeColor1603776877564' |  | ||||||
| 
 |  | ||||||
|     public async up(queryRunner: QueryRunner): Promise<void> { |  | ||||||
|         await queryRunner.query(`ALTER TABLE "instance" ADD "themeColor" character varying(64) DEFAULT null`); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     public async down(queryRunner: QueryRunner): Promise<void> { |  | ||||||
|         await queryRunner.query(`ALTER TABLE "instance" DROP COLUMN "themeColor"`); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
| } |  | ||||||
|  | @ -1,14 +0,0 @@ | ||||||
| import {MigrationInterface, QueryRunner} from "typeorm"; |  | ||||||
| 
 |  | ||||||
| export class instanceFavicon1603781553011 implements MigrationInterface { |  | ||||||
|     name = 'instanceFavicon1603781553011' |  | ||||||
| 
 |  | ||||||
|     public async up(queryRunner: QueryRunner): Promise<void> { |  | ||||||
|         await queryRunner.query(`ALTER TABLE "instance" ADD "faviconUrl" character varying(256) DEFAULT null`); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     public async down(queryRunner: QueryRunner): Promise<void> { |  | ||||||
|         await queryRunner.query(`ALTER TABLE "instance" DROP COLUMN "faviconUrl"`); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
| } |  | ||||||
|  | @ -1,14 +0,0 @@ | ||||||
| import {MigrationInterface, QueryRunner} from "typeorm"; |  | ||||||
| 
 |  | ||||||
| export class deleteAutoWatch1604821689616 implements MigrationInterface { |  | ||||||
|     name = 'deleteAutoWatch1604821689616' |  | ||||||
| 
 |  | ||||||
|     public async up(queryRunner: QueryRunner): Promise<void> { |  | ||||||
|         await queryRunner.query(`ALTER TABLE "user_profile" DROP COLUMN "autoWatch"`); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     public async down(queryRunner: QueryRunner): Promise<void> { |  | ||||||
|         await queryRunner.query(`ALTER TABLE "user_profile" ADD "autoWatch" boolean NOT NULL DEFAULT false`); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
| } |  | ||||||
|  | @ -1,15 +0,0 @@ | ||||||
| import {MigrationInterface, QueryRunner} from "typeorm"; |  | ||||||
| 
 |  | ||||||
| export class clipDescription1605408848373 implements MigrationInterface { |  | ||||||
|     name = 'clipDescription1605408848373' |  | ||||||
| 
 |  | ||||||
|     public async up(queryRunner: QueryRunner): Promise<void> { |  | ||||||
|         await queryRunner.query(`ALTER TABLE "clip" ADD "description" character varying(2048) DEFAULT null`); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     public async down(queryRunner: QueryRunner): Promise<void> { |  | ||||||
| 
 |  | ||||||
|         await queryRunner.query(`ALTER TABLE "clip" DROP COLUMN "description"`); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
| } |  | ||||||
|  | @ -1,14 +0,0 @@ | ||||||
| import {MigrationInterface, QueryRunner} from "typeorm"; |  | ||||||
| 
 |  | ||||||
| export class instancePinnedPages1605585339718 implements MigrationInterface { |  | ||||||
|     name = 'instancePinnedPages1605585339718' |  | ||||||
| 
 |  | ||||||
|     public async up(queryRunner: QueryRunner): Promise<void> { |  | ||||||
|         await queryRunner.query(`ALTER TABLE "meta" ADD "pinnedPages" character varying(512) array NOT NULL DEFAULT '{"/featured", "/channels", "/explore", "/pages", "/about-misskey"}'::varchar[]`); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     public async down(queryRunner: QueryRunner): Promise<void> { |  | ||||||
|         await queryRunner.query(`ALTER TABLE "meta" DROP COLUMN "pinnedPages"`); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
| } |  | ||||||
|  | @ -1,14 +0,0 @@ | ||||||
| import {MigrationInterface, QueryRunner} from "typeorm"; |  | ||||||
| 
 |  | ||||||
| export class instancePinnedClip1607151207216 implements MigrationInterface { |  | ||||||
|     name = 'instancePinnedClip1607151207216' |  | ||||||
| 
 |  | ||||||
|     public async up(queryRunner: QueryRunner): Promise<void> { |  | ||||||
|         await queryRunner.query(`ALTER TABLE "meta" ADD "pinnedClipId" character varying(32)`); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     public async down(queryRunner: QueryRunner): Promise<void> { |  | ||||||
|         await queryRunner.query(`ALTER TABLE "meta" DROP COLUMN "pinnedClipId"`); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
| } |  | ||||||
|  | @ -1,14 +0,0 @@ | ||||||
| import {MigrationInterface, QueryRunner} from "typeorm"; |  | ||||||
| 
 |  | ||||||
| export class registry31610283021566 implements MigrationInterface { |  | ||||||
|     name = 'registry31610283021566' |  | ||||||
| 
 |  | ||||||
|     public async up(queryRunner: QueryRunner): Promise<void> { |  | ||||||
|         await queryRunner.query(`ALTER TABLE "registry_item" ALTER COLUMN "value" DROP NOT NULL`); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     public async down(queryRunner: QueryRunner): Promise<void> { |  | ||||||
|         await queryRunner.query(`ALTER TABLE "registry_item" ALTER COLUMN "value" SET NOT NULL`); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
| } |  | ||||||
|  | @ -1,14 +0,0 @@ | ||||||
| import {MigrationInterface, QueryRunner} from "typeorm"; |  | ||||||
| 
 |  | ||||||
| export class objectStorageS3ForcePathStyle1611547387175 implements MigrationInterface { |  | ||||||
|     name = 'objectStorageS3ForcePathStyle1611547387175' |  | ||||||
| 
 |  | ||||||
|     public async up(queryRunner: QueryRunner): Promise<void> { |  | ||||||
|         await queryRunner.query(`ALTER TABLE "meta" ADD "objectStorageS3ForcePathStyle" boolean NOT NULL DEFAULT true`); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     public async down(queryRunner: QueryRunner): Promise<void> { |  | ||||||
|         await queryRunner.query(`ALTER TABLE "meta" DROP COLUMN "objectStorageS3ForcePathStyle"`); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
| } |  | ||||||
|  | @ -1,14 +0,0 @@ | ||||||
| import {MigrationInterface, QueryRunner} from "typeorm"; |  | ||||||
| 
 |  | ||||||
| export class announcementEmail1612619156584 implements MigrationInterface { |  | ||||||
|     name = 'announcementEmail1612619156584' |  | ||||||
| 
 |  | ||||||
|     public async up(queryRunner: QueryRunner): Promise<void> { |  | ||||||
|         await queryRunner.query(`ALTER TABLE "user_profile" ADD "receiveAnnouncementEmail" boolean NOT NULL DEFAULT true`); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     public async down(queryRunner: QueryRunner): Promise<void> { |  | ||||||
|         await queryRunner.query(`ALTER TABLE "user_profile" DROP COLUMN "receiveAnnouncementEmail"`); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
| } |  | ||||||
|  | @ -1,14 +0,0 @@ | ||||||
| import {MigrationInterface, QueryRunner} from "typeorm"; |  | ||||||
| 
 |  | ||||||
| export class emailNotificationTypes1613155914446 implements MigrationInterface { |  | ||||||
|     name = 'emailNotificationTypes1613155914446' |  | ||||||
| 
 |  | ||||||
|     public async up(queryRunner: QueryRunner): Promise<void> { |  | ||||||
|         await queryRunner.query(`ALTER TABLE "user_profile" ADD "emailNotificationTypes" jsonb NOT NULL DEFAULT '["follow","receiveFollowRequest","groupInvited"]'`); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     public async down(queryRunner: QueryRunner): Promise<void> { |  | ||||||
|         await queryRunner.query(`ALTER TABLE "user_profile" DROP COLUMN "emailNotificationTypes"`); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
| } |  | ||||||
|  | @ -1,14 +0,0 @@ | ||||||
| import {MigrationInterface, QueryRunner} from "typeorm"; |  | ||||||
| 
 |  | ||||||
| export class userLang1613181457597 implements MigrationInterface { |  | ||||||
|     name = 'userLang1613181457597' |  | ||||||
| 
 |  | ||||||
|     public async up(queryRunner: QueryRunner): Promise<void> { |  | ||||||
|         await queryRunner.query(`ALTER TABLE "user_profile" ADD "lang" character varying(32)`); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     public async down(queryRunner: QueryRunner): Promise<void> { |  | ||||||
|         await queryRunner.query(`ALTER TABLE "user_profile" DROP COLUMN "lang"`); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
| } |  | ||||||
|  | @ -1,15 +0,0 @@ | ||||||
| import {MigrationInterface, QueryRunner} from "typeorm"; |  | ||||||
| 
 |  | ||||||
| export class useBigintForDriveUsage1613503367223 implements MigrationInterface { |  | ||||||
|     name = 'useBigintForDriveUsage1613503367223' |  | ||||||
| 
 |  | ||||||
|     public async up(queryRunner: QueryRunner): Promise<void> { |  | ||||||
|         await queryRunner.query(`ALTER TABLE "instance" ALTER COLUMN "driveUsage" TYPE bigint`); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     public async down(queryRunner: QueryRunner): Promise<void> { |  | ||||||
|         await queryRunner.query(`ALTER TABLE "instance" DROP COLUMN "driveUsage"`); |  | ||||||
|         await queryRunner.query(`ALTER TABLE "instance" ADD "driveUsage" integer NOT NULL DEFAULT 0`); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
| } |  | ||||||
|  | @ -1,218 +0,0 @@ | ||||||
| import {MigrationInterface, QueryRunner} from "typeorm"; |  | ||||||
| 
 |  | ||||||
| export class chartV21615965918224 implements MigrationInterface { |  | ||||||
| 	name = 'chartV21615965918224' |  | ||||||
| 
 |  | ||||||
| 	public async up(queryRunner: QueryRunner): Promise<void> { |  | ||||||
| 		await queryRunner.query(`DELETE FROM "__chart__active_users" WHERE "span" = 'day'`); |  | ||||||
| 		await queryRunner.query(`DELETE FROM "__chart__drive" WHERE "span" = 'day'`); |  | ||||||
| 		await queryRunner.query(`DELETE FROM "__chart__federation" WHERE "span" = 'day'`); |  | ||||||
| 		await queryRunner.query(`DELETE FROM "__chart__hashtag" WHERE "span" = 'day'`); |  | ||||||
| 		await queryRunner.query(`DELETE FROM "__chart__instance" WHERE "span" = 'day'`); |  | ||||||
| 		await queryRunner.query(`DELETE FROM "__chart__network" WHERE "span" = 'day'`); |  | ||||||
| 		await queryRunner.query(`DELETE FROM "__chart__notes" WHERE "span" = 'day'`); |  | ||||||
| 		await queryRunner.query(`DELETE FROM "__chart__per_user_drive" WHERE "span" = 'day'`); |  | ||||||
| 		await queryRunner.query(`DELETE FROM "__chart__per_user_following" WHERE "span" = 'day'`); |  | ||||||
| 		await queryRunner.query(`DELETE FROM "__chart__per_user_notes" WHERE "span" = 'day'`); |  | ||||||
| 		await queryRunner.query(`DELETE FROM "__chart__per_user_reaction" WHERE "span" = 'day'`); |  | ||||||
| 		await queryRunner.query(`DELETE FROM "__chart__test" WHERE "span" = 'day'`); |  | ||||||
| 		await queryRunner.query(`DELETE FROM "__chart__test_grouped" WHERE "span" = 'day'`); |  | ||||||
| 		await queryRunner.query(`DELETE FROM "__chart__test_unique" WHERE "span" = 'day'`); |  | ||||||
| 		await queryRunner.query(`DELETE FROM "__chart__users" WHERE "span" = 'day'`); |  | ||||||
| 
 |  | ||||||
| 		await queryRunner.query(`DROP INDEX "IDX_15e91a03aeeac9dbccdf43fc06"`); |  | ||||||
| 		await queryRunner.query(`DROP INDEX "IDX_20f57cc8f142c131340ee16742"`); |  | ||||||
| 		await queryRunner.query(`DROP INDEX "IDX_c26e2c1cbb6e911e0554b27416"`); |  | ||||||
| 		await queryRunner.query(`DROP INDEX "IDX_3fa0d0f17ca72e3dc80999a032"`); |  | ||||||
| 		await queryRunner.query(`DROP INDEX "IDX_6e1df243476e20cbf86572ecc0"`); |  | ||||||
| 		await queryRunner.query(`DROP INDEX "IDX_06690fc959f1c9fdaf21928222"`); |  | ||||||
| 		await queryRunner.query(`DROP INDEX "IDX_e447064455928cf627590ef527"`); |  | ||||||
| 		await queryRunner.query(`DROP INDEX "IDX_2d416e6af791a82e338c79d480"`); |  | ||||||
| 		await queryRunner.query(`DROP INDEX "IDX_e9cd07672b37d8966cf3709283"`); |  | ||||||
| 		await queryRunner.query(`DROP INDEX "IDX_fcc181fb8283009c61cc4083ef"`); |  | ||||||
| 		await queryRunner.query(`DROP INDEX "IDX_49975586f50ed7b800fdd88fbd"`); |  | ||||||
| 		await queryRunner.query(`DROP INDEX "IDX_6d6f156ceefc6bc5f273a0e370"`); |  | ||||||
| 		await queryRunner.query(`DROP INDEX "IDX_c12f0af4a66cdd30c2287ce8aa"`); |  | ||||||
| 		await queryRunner.query(`DROP INDEX "IDX_d0a4f79af5a97b08f37b547197"`); |  | ||||||
| 		await queryRunner.query(`DROP INDEX "IDX_f5448d9633cff74208d850aabe"`); |  | ||||||
| 		await queryRunner.query(`DROP INDEX "IDX_f8dd01baeded2ffa833e0a610a"`); |  | ||||||
| 		await queryRunner.query(`DROP INDEX "IDX_08fac0eb3b11f04c200c0b40dd"`); |  | ||||||
| 		await queryRunner.query(`DROP INDEX "IDX_9ff6944f01acb756fdc92d7563"`); |  | ||||||
| 		await queryRunner.query(`DROP INDEX "IDX_e69096589f11e3baa98ddd64d0"`); |  | ||||||
| 		await queryRunner.query(`DROP INDEX "IDX_0c9a159c5082cbeef3ca6706b5"`); |  | ||||||
| 		await queryRunner.query(`DROP INDEX "IDX_924fc196c80ca24bae01dd37e4"`); |  | ||||||
| 		await queryRunner.query(`DROP INDEX "IDX_328f259961e60c4fa0bfcf55ca"`); |  | ||||||
| 		await queryRunner.query(`DROP INDEX "IDX_42ea9381f0fda8dfe0fa1c8b53"`); |  | ||||||
| 		await queryRunner.query(`DROP INDEX "IDX_f2aeafde2ae6fbad38e857631b"`); |  | ||||||
| 		await queryRunner.query(`DROP INDEX "IDX_f92dd6d03f8d994f29987f6214"`); |  | ||||||
| 		await queryRunner.query(`DROP INDEX "IDX_57b5458d0d3d6d1e7f13d4e57f"`); |  | ||||||
| 		await queryRunner.query(`DROP INDEX "IDX_4db3b84c7be0d3464714f3e0b1"`); |  | ||||||
| 		await queryRunner.query(`DROP INDEX "IDX_8d2cbbc8114d90d19b44d626b6"`); |  | ||||||
| 		await queryRunner.query(`DROP INDEX "IDX_046feeb12e9ef5f783f409866a"`); |  | ||||||
| 		await queryRunner.query(`DROP INDEX "IDX_f68a5ab958f9f5fa17a32ac23b"`); |  | ||||||
| 		await queryRunner.query(`DROP INDEX "IDX_65633a106bce43fc7c5c30a5c7"`); |  | ||||||
| 		await queryRunner.query(`DROP INDEX "IDX_edeb73c09c3143a81bcb34d569"`); |  | ||||||
| 		await queryRunner.query(`DROP INDEX "IDX_e316f01a6d24eb31db27f88262"`); |  | ||||||
| 		await queryRunner.query(`DROP INDEX "IDX_2be7ec6cebddc14dc11e206686"`); |  | ||||||
| 		await queryRunner.query(`DROP INDEX "IDX_a5133470f4825902e170328ca5"`); |  | ||||||
| 		await queryRunner.query(`DROP INDEX "IDX_84e661abb7bd1e51b690d4b017"`); |  | ||||||
| 		await queryRunner.query(`DROP INDEX "IDX_5c73bf61da4f6e6f15bae88ed1"`); |  | ||||||
| 		await queryRunner.query(`DROP INDEX "IDX_d70c86baedc68326be11f9c0ce"`); |  | ||||||
| 		await queryRunner.query(`DROP INDEX "IDX_66e1e1ecd2f29e57778af35b59"`); |  | ||||||
| 		await queryRunner.query(`DROP INDEX "IDX_92255988735563f0fe4aba1f05"`); |  | ||||||
| 		await queryRunner.query(`DROP INDEX "IDX_c5870993e25c3d5771f91f5003"`); |  | ||||||
| 		await queryRunner.query(`DROP INDEX "IDX_f170de677ea75ad4533de2723e"`); |  | ||||||
| 		await queryRunner.query(`DROP INDEX "IDX_7c184198ecf66a8d3ecb253ab3"`); |  | ||||||
| 		await queryRunner.query(`DROP INDEX "IDX_f091abb24193d50c653c6b77fc"`); |  | ||||||
| 		await queryRunner.query(`DROP INDEX "IDX_a770a57c70e668cc61590c9161"`); |  | ||||||
| 		await queryRunner.query(`ALTER TABLE "__chart__active_users" DROP COLUMN "span"`); |  | ||||||
| 		await queryRunner.query(`DROP TYPE "public"."__chart__active_users_span_enum"`); |  | ||||||
| 		await queryRunner.query(`ALTER TABLE "__chart__active_users" DROP COLUMN "unique"`); |  | ||||||
| 		await queryRunner.query(`ALTER TABLE "__chart__active_users" DROP COLUMN "___local_count"`); |  | ||||||
| 		await queryRunner.query(`ALTER TABLE "__chart__active_users" DROP COLUMN "___remote_count"`); |  | ||||||
| 		await queryRunner.query(`ALTER TABLE "__chart__drive" DROP COLUMN "span"`); |  | ||||||
| 		await queryRunner.query(`DROP TYPE "public"."__chart__drive_span_enum"`); |  | ||||||
| 		await queryRunner.query(`ALTER TABLE "__chart__drive" DROP COLUMN "unique"`); |  | ||||||
| 		await queryRunner.query(`ALTER TABLE "__chart__federation" DROP COLUMN "span"`); |  | ||||||
| 		await queryRunner.query(`DROP TYPE "public"."__chart__federation_span_enum"`); |  | ||||||
| 		await queryRunner.query(`ALTER TABLE "__chart__federation" DROP COLUMN "unique"`); |  | ||||||
| 		await queryRunner.query(`ALTER TABLE "__chart__hashtag" DROP COLUMN "span"`); |  | ||||||
| 		await queryRunner.query(`DROP TYPE "public"."__chart__hashtag_span_enum"`); |  | ||||||
| 		await queryRunner.query(`ALTER TABLE "__chart__hashtag" DROP COLUMN "unique"`); |  | ||||||
| 		await queryRunner.query(`ALTER TABLE "__chart__hashtag" DROP COLUMN "___local_count"`); |  | ||||||
| 		await queryRunner.query(`ALTER TABLE "__chart__hashtag" DROP COLUMN "___remote_count"`); |  | ||||||
| 		await queryRunner.query(`ALTER TABLE "__chart__instance" DROP COLUMN "span"`); |  | ||||||
| 		await queryRunner.query(`DROP TYPE "public"."__chart__instance_span_enum"`); |  | ||||||
| 		await queryRunner.query(`ALTER TABLE "__chart__instance" DROP COLUMN "unique"`); |  | ||||||
| 		await queryRunner.query(`ALTER TABLE "__chart__network" DROP COLUMN "span"`); |  | ||||||
| 		await queryRunner.query(`DROP TYPE "public"."__chart__network_span_enum"`); |  | ||||||
| 		await queryRunner.query(`ALTER TABLE "__chart__network" DROP COLUMN "unique"`); |  | ||||||
| 		await queryRunner.query(`ALTER TABLE "__chart__notes" DROP COLUMN "span"`); |  | ||||||
| 		await queryRunner.query(`DROP TYPE "public"."__chart__notes_span_enum"`); |  | ||||||
| 		await queryRunner.query(`ALTER TABLE "__chart__notes" DROP COLUMN "unique"`); |  | ||||||
| 		await queryRunner.query(`ALTER TABLE "__chart__per_user_drive" DROP COLUMN "span"`); |  | ||||||
| 		await queryRunner.query(`DROP TYPE "public"."__chart__per_user_drive_span_enum"`); |  | ||||||
| 		await queryRunner.query(`ALTER TABLE "__chart__per_user_drive" DROP COLUMN "unique"`); |  | ||||||
| 		await queryRunner.query(`ALTER TABLE "__chart__per_user_following" DROP COLUMN "span"`); |  | ||||||
| 		await queryRunner.query(`DROP TYPE "public"."__chart__per_user_following_span_enum"`); |  | ||||||
| 		await queryRunner.query(`ALTER TABLE "__chart__per_user_following" DROP COLUMN "unique"`); |  | ||||||
| 		await queryRunner.query(`ALTER TABLE "__chart__per_user_notes" DROP COLUMN "span"`); |  | ||||||
| 		await queryRunner.query(`DROP TYPE "public"."__chart__per_user_notes_span_enum"`); |  | ||||||
| 		await queryRunner.query(`ALTER TABLE "__chart__per_user_notes" DROP COLUMN "unique"`); |  | ||||||
| 		await queryRunner.query(`ALTER TABLE "__chart__per_user_reaction" DROP COLUMN "span"`); |  | ||||||
| 		await queryRunner.query(`DROP TYPE "public"."__chart__per_user_reaction_span_enum"`); |  | ||||||
| 		await queryRunner.query(`ALTER TABLE "__chart__per_user_reaction" DROP COLUMN "unique"`); |  | ||||||
| 		await queryRunner.query(`ALTER TABLE "__chart__test_grouped" DROP COLUMN "span"`); |  | ||||||
| 		await queryRunner.query(`DROP TYPE "public"."__chart__test_grouped_span_enum"`); |  | ||||||
| 		await queryRunner.query(`ALTER TABLE "__chart__test_grouped" DROP COLUMN "unique"`); |  | ||||||
| 		await queryRunner.query(`ALTER TABLE "__chart__test_unique" DROP COLUMN "span"`); |  | ||||||
| 		await queryRunner.query(`DROP TYPE "public"."__chart__test_unique_span_enum"`); |  | ||||||
| 		await queryRunner.query(`ALTER TABLE "__chart__test_unique" DROP COLUMN "unique"`); |  | ||||||
| 		await queryRunner.query(`ALTER TABLE "__chart__test_unique" DROP COLUMN "___foo"`); |  | ||||||
| 		await queryRunner.query(`ALTER TABLE "__chart__test" DROP COLUMN "span"`); |  | ||||||
| 		await queryRunner.query(`DROP TYPE "public"."__chart__test_span_enum"`); |  | ||||||
| 		await queryRunner.query(`ALTER TABLE "__chart__test" DROP COLUMN "unique"`); |  | ||||||
| 		await queryRunner.query(`ALTER TABLE "__chart__users" DROP COLUMN "span"`); |  | ||||||
| 		await queryRunner.query(`DROP TYPE "public"."__chart__users_span_enum"`); |  | ||||||
| 		await queryRunner.query(`ALTER TABLE "__chart__users" DROP COLUMN "unique"`); |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	public async down(queryRunner: QueryRunner): Promise<void> { |  | ||||||
| 		await queryRunner.query(`ALTER TABLE "__chart__users" ADD "unique" jsonb NOT NULL DEFAULT '{}'`); |  | ||||||
| 		await queryRunner.query(`CREATE TYPE "public"."__chart__users_span_enum" AS ENUM('hour', 'day')`); |  | ||||||
| 		await queryRunner.query(`ALTER TABLE "__chart__users" ADD "span" "__chart__users_span_enum" NOT NULL`); |  | ||||||
| 		await queryRunner.query(`ALTER TABLE "__chart__test" ADD "unique" jsonb NOT NULL DEFAULT '{}'`); |  | ||||||
| 		await queryRunner.query(`CREATE TYPE "public"."__chart__test_span_enum" AS ENUM('hour', 'day')`); |  | ||||||
| 		await queryRunner.query(`ALTER TABLE "__chart__test" ADD "span" "__chart__test_span_enum" NOT NULL`); |  | ||||||
| 		await queryRunner.query(`ALTER TABLE "__chart__test_unique" ADD "___foo" bigint NOT NULL`); |  | ||||||
| 		await queryRunner.query(`ALTER TABLE "__chart__test_unique" ADD "unique" jsonb NOT NULL DEFAULT '{}'`); |  | ||||||
| 		await queryRunner.query(`CREATE TYPE "public"."__chart__test_unique_span_enum" AS ENUM('hour', 'day')`); |  | ||||||
| 		await queryRunner.query(`ALTER TABLE "__chart__test_unique" ADD "span" "__chart__test_unique_span_enum" NOT NULL`); |  | ||||||
| 		await queryRunner.query(`ALTER TABLE "__chart__test_grouped" ADD "unique" jsonb NOT NULL DEFAULT '{}'`); |  | ||||||
| 		await queryRunner.query(`CREATE TYPE "public"."__chart__test_grouped_span_enum" AS ENUM('hour', 'day')`); |  | ||||||
| 		await queryRunner.query(`ALTER TABLE "__chart__test_grouped" ADD "span" "__chart__test_grouped_span_enum" NOT NULL`); |  | ||||||
| 		await queryRunner.query(`ALTER TABLE "__chart__per_user_reaction" ADD "unique" jsonb NOT NULL DEFAULT '{}'`); |  | ||||||
| 		await queryRunner.query(`CREATE TYPE "public"."__chart__per_user_reaction_span_enum" AS ENUM('hour', 'day')`); |  | ||||||
| 		await queryRunner.query(`ALTER TABLE "__chart__per_user_reaction" ADD "span" "__chart__per_user_reaction_span_enum" NOT NULL`); |  | ||||||
| 		await queryRunner.query(`ALTER TABLE "__chart__per_user_notes" ADD "unique" jsonb NOT NULL DEFAULT '{}'`); |  | ||||||
| 		await queryRunner.query(`CREATE TYPE "public"."__chart__per_user_notes_span_enum" AS ENUM('hour', 'day')`); |  | ||||||
| 		await queryRunner.query(`ALTER TABLE "__chart__per_user_notes" ADD "span" "__chart__per_user_notes_span_enum" NOT NULL`); |  | ||||||
| 		await queryRunner.query(`ALTER TABLE "__chart__per_user_following" ADD "unique" jsonb NOT NULL DEFAULT '{}'`); |  | ||||||
| 		await queryRunner.query(`CREATE TYPE "public"."__chart__per_user_following_span_enum" AS ENUM('hour', 'day')`); |  | ||||||
| 		await queryRunner.query(`ALTER TABLE "__chart__per_user_following" ADD "span" "__chart__per_user_following_span_enum" NOT NULL`); |  | ||||||
| 		await queryRunner.query(`ALTER TABLE "__chart__per_user_drive" ADD "unique" jsonb NOT NULL DEFAULT '{}'`); |  | ||||||
| 		await queryRunner.query(`CREATE TYPE "public"."__chart__per_user_drive_span_enum" AS ENUM('hour', 'day')`); |  | ||||||
| 		await queryRunner.query(`ALTER TABLE "__chart__per_user_drive" ADD "span" "__chart__per_user_drive_span_enum" NOT NULL`); |  | ||||||
| 		await queryRunner.query(`ALTER TABLE "__chart__notes" ADD "unique" jsonb NOT NULL DEFAULT '{}'`); |  | ||||||
| 		await queryRunner.query(`CREATE TYPE "public"."__chart__notes_span_enum" AS ENUM('hour', 'day')`); |  | ||||||
| 		await queryRunner.query(`ALTER TABLE "__chart__notes" ADD "span" "__chart__notes_span_enum" NOT NULL`); |  | ||||||
| 		await queryRunner.query(`ALTER TABLE "__chart__network" ADD "unique" jsonb NOT NULL DEFAULT '{}'`); |  | ||||||
| 		await queryRunner.query(`CREATE TYPE "public"."__chart__network_span_enum" AS ENUM('hour', 'day')`); |  | ||||||
| 		await queryRunner.query(`ALTER TABLE "__chart__network" ADD "span" "__chart__network_span_enum" NOT NULL`); |  | ||||||
| 		await queryRunner.query(`ALTER TABLE "__chart__instance" ADD "unique" jsonb NOT NULL DEFAULT '{}'`); |  | ||||||
| 		await queryRunner.query(`CREATE TYPE "public"."__chart__instance_span_enum" AS ENUM('hour', 'day')`); |  | ||||||
| 		await queryRunner.query(`ALTER TABLE "__chart__instance" ADD "span" "__chart__instance_span_enum" NOT NULL`); |  | ||||||
| 		await queryRunner.query(`ALTER TABLE "__chart__hashtag" ADD "___remote_count" bigint NOT NULL`); |  | ||||||
| 		await queryRunner.query(`ALTER TABLE "__chart__hashtag" ADD "___local_count" bigint NOT NULL`); |  | ||||||
| 		await queryRunner.query(`ALTER TABLE "__chart__hashtag" ADD "unique" jsonb NOT NULL DEFAULT '{}'`); |  | ||||||
| 		await queryRunner.query(`CREATE TYPE "public"."__chart__hashtag_span_enum" AS ENUM('hour', 'day')`); |  | ||||||
| 		await queryRunner.query(`ALTER TABLE "__chart__hashtag" ADD "span" "__chart__hashtag_span_enum" NOT NULL`); |  | ||||||
| 		await queryRunner.query(`ALTER TABLE "__chart__federation" ADD "unique" jsonb NOT NULL DEFAULT '{}'`); |  | ||||||
| 		await queryRunner.query(`CREATE TYPE "public"."__chart__federation_span_enum" AS ENUM('hour', 'day')`); |  | ||||||
| 		await queryRunner.query(`ALTER TABLE "__chart__federation" ADD "span" "__chart__federation_span_enum" NOT NULL`); |  | ||||||
| 		await queryRunner.query(`ALTER TABLE "__chart__drive" ADD "unique" jsonb NOT NULL DEFAULT '{}'`); |  | ||||||
| 		await queryRunner.query(`CREATE TYPE "public"."__chart__drive_span_enum" AS ENUM('hour', 'day')`); |  | ||||||
| 		await queryRunner.query(`ALTER TABLE "__chart__drive" ADD "span" "__chart__drive_span_enum" NOT NULL`); |  | ||||||
| 		await queryRunner.query(`ALTER TABLE "__chart__active_users" ADD "___remote_count" bigint NOT NULL`); |  | ||||||
| 		await queryRunner.query(`ALTER TABLE "__chart__active_users" ADD "___local_count" bigint NOT NULL`); |  | ||||||
| 		await queryRunner.query(`ALTER TABLE "__chart__active_users" ADD "unique" jsonb NOT NULL DEFAULT '{}'`); |  | ||||||
| 		await queryRunner.query(`CREATE TYPE "public"."__chart__active_users_span_enum" AS ENUM('hour', 'day')`); |  | ||||||
| 		await queryRunner.query(`ALTER TABLE "__chart__active_users" ADD "span" "__chart__active_users_span_enum" NOT NULL`); |  | ||||||
| 		await queryRunner.query(`CREATE INDEX "IDX_a770a57c70e668cc61590c9161" ON "__chart__users" ("date", "group", "span") `); |  | ||||||
| 		await queryRunner.query(`CREATE INDEX "IDX_f091abb24193d50c653c6b77fc" ON "__chart__users" ("date", "span") `); |  | ||||||
| 		await queryRunner.query(`CREATE INDEX "IDX_7c184198ecf66a8d3ecb253ab3" ON "__chart__users" ("span") `); |  | ||||||
| 		await queryRunner.query(`CREATE INDEX "IDX_f170de677ea75ad4533de2723e" ON "__chart__test" ("date", "group", "span") `); |  | ||||||
| 		await queryRunner.query(`CREATE INDEX "IDX_c5870993e25c3d5771f91f5003" ON "__chart__test" ("date", "span") `); |  | ||||||
| 		await queryRunner.query(`CREATE INDEX "IDX_92255988735563f0fe4aba1f05" ON "__chart__test" ("span") `); |  | ||||||
| 		await queryRunner.query(`CREATE INDEX "IDX_66e1e1ecd2f29e57778af35b59" ON "__chart__test_unique" ("date", "group", "span") `); |  | ||||||
| 		await queryRunner.query(`CREATE INDEX "IDX_d70c86baedc68326be11f9c0ce" ON "__chart__test_unique" ("date", "span") `); |  | ||||||
| 		await queryRunner.query(`CREATE INDEX "IDX_5c73bf61da4f6e6f15bae88ed1" ON "__chart__test_unique" ("span") `); |  | ||||||
| 		await queryRunner.query(`CREATE INDEX "IDX_84e661abb7bd1e51b690d4b017" ON "__chart__test_grouped" ("date", "group", "span") `); |  | ||||||
| 		await queryRunner.query(`CREATE INDEX "IDX_a5133470f4825902e170328ca5" ON "__chart__test_grouped" ("date", "span") `); |  | ||||||
| 		await queryRunner.query(`CREATE INDEX "IDX_2be7ec6cebddc14dc11e206686" ON "__chart__test_grouped" ("span") `); |  | ||||||
| 		await queryRunner.query(`CREATE INDEX "IDX_e316f01a6d24eb31db27f88262" ON "__chart__per_user_reaction" ("date", "group", "span") `); |  | ||||||
| 		await queryRunner.query(`CREATE INDEX "IDX_edeb73c09c3143a81bcb34d569" ON "__chart__per_user_reaction" ("date", "span") `); |  | ||||||
| 		await queryRunner.query(`CREATE INDEX "IDX_65633a106bce43fc7c5c30a5c7" ON "__chart__per_user_reaction" ("span") `); |  | ||||||
| 		await queryRunner.query(`CREATE INDEX "IDX_f68a5ab958f9f5fa17a32ac23b" ON "__chart__per_user_notes" ("date", "group", "span") `); |  | ||||||
| 		await queryRunner.query(`CREATE INDEX "IDX_046feeb12e9ef5f783f409866a" ON "__chart__per_user_notes" ("date", "span") `); |  | ||||||
| 		await queryRunner.query(`CREATE INDEX "IDX_8d2cbbc8114d90d19b44d626b6" ON "__chart__per_user_notes" ("span") `); |  | ||||||
| 		await queryRunner.query(`CREATE INDEX "IDX_4db3b84c7be0d3464714f3e0b1" ON "__chart__per_user_following" ("date", "group", "span") `); |  | ||||||
| 		await queryRunner.query(`CREATE INDEX "IDX_57b5458d0d3d6d1e7f13d4e57f" ON "__chart__per_user_following" ("date", "span") `); |  | ||||||
| 		await queryRunner.query(`CREATE INDEX "IDX_f92dd6d03f8d994f29987f6214" ON "__chart__per_user_following" ("span") `); |  | ||||||
| 		await queryRunner.query(`CREATE INDEX "IDX_f2aeafde2ae6fbad38e857631b" ON "__chart__per_user_drive" ("date", "group", "span") `); |  | ||||||
| 		await queryRunner.query(`CREATE INDEX "IDX_42ea9381f0fda8dfe0fa1c8b53" ON "__chart__per_user_drive" ("date", "span") `); |  | ||||||
| 		await queryRunner.query(`CREATE INDEX "IDX_328f259961e60c4fa0bfcf55ca" ON "__chart__per_user_drive" ("span") `); |  | ||||||
| 		await queryRunner.query(`CREATE INDEX "IDX_924fc196c80ca24bae01dd37e4" ON "__chart__notes" ("date", "group", "span") `); |  | ||||||
| 		await queryRunner.query(`CREATE INDEX "IDX_0c9a159c5082cbeef3ca6706b5" ON "__chart__notes" ("date", "span") `); |  | ||||||
| 		await queryRunner.query(`CREATE INDEX "IDX_e69096589f11e3baa98ddd64d0" ON "__chart__notes" ("span") `); |  | ||||||
| 		await queryRunner.query(`CREATE INDEX "IDX_9ff6944f01acb756fdc92d7563" ON "__chart__network" ("date", "group", "span") `); |  | ||||||
| 		await queryRunner.query(`CREATE INDEX "IDX_08fac0eb3b11f04c200c0b40dd" ON "__chart__network" ("date", "span") `); |  | ||||||
| 		await queryRunner.query(`CREATE INDEX "IDX_f8dd01baeded2ffa833e0a610a" ON "__chart__network" ("span") `); |  | ||||||
| 		await queryRunner.query(`CREATE INDEX "IDX_f5448d9633cff74208d850aabe" ON "__chart__instance" ("date", "group", "span") `); |  | ||||||
| 		await queryRunner.query(`CREATE INDEX "IDX_d0a4f79af5a97b08f37b547197" ON "__chart__instance" ("date", "span") `); |  | ||||||
| 		await queryRunner.query(`CREATE INDEX "IDX_c12f0af4a66cdd30c2287ce8aa" ON "__chart__instance" ("span") `); |  | ||||||
| 		await queryRunner.query(`CREATE INDEX "IDX_6d6f156ceefc6bc5f273a0e370" ON "__chart__hashtag" ("date", "group", "span") `); |  | ||||||
| 		await queryRunner.query(`CREATE INDEX "IDX_49975586f50ed7b800fdd88fbd" ON "__chart__hashtag" ("date", "span") `); |  | ||||||
| 		await queryRunner.query(`CREATE INDEX "IDX_fcc181fb8283009c61cc4083ef" ON "__chart__hashtag" ("span") `); |  | ||||||
| 		await queryRunner.query(`CREATE INDEX "IDX_e9cd07672b37d8966cf3709283" ON "__chart__federation" ("date", "group", "span") `); |  | ||||||
| 		await queryRunner.query(`CREATE INDEX "IDX_2d416e6af791a82e338c79d480" ON "__chart__federation" ("date", "span") `); |  | ||||||
| 		await queryRunner.query(`CREATE INDEX "IDX_e447064455928cf627590ef527" ON "__chart__federation" ("span") `); |  | ||||||
| 		await queryRunner.query(`CREATE INDEX "IDX_06690fc959f1c9fdaf21928222" ON "__chart__drive" ("date", "group", "span") `); |  | ||||||
| 		await queryRunner.query(`CREATE INDEX "IDX_6e1df243476e20cbf86572ecc0" ON "__chart__drive" ("date", "span") `); |  | ||||||
| 		await queryRunner.query(`CREATE INDEX "IDX_3fa0d0f17ca72e3dc80999a032" ON "__chart__drive" ("span") `); |  | ||||||
| 		await queryRunner.query(`CREATE INDEX "IDX_c26e2c1cbb6e911e0554b27416" ON "__chart__active_users" ("date", "group", "span") `); |  | ||||||
| 		await queryRunner.query(`CREATE INDEX "IDX_20f57cc8f142c131340ee16742" ON "__chart__active_users" ("date", "span") `); |  | ||||||
| 		await queryRunner.query(`CREATE INDEX "IDX_15e91a03aeeac9dbccdf43fc06" ON "__chart__active_users" ("span") `); |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| } |  | ||||||
|  | @ -1,14 +0,0 @@ | ||||||
| import {MigrationInterface, QueryRunner} from "typeorm"; |  | ||||||
| 
 |  | ||||||
| export class userHideOnlineStatus1618639857000 implements MigrationInterface { |  | ||||||
|     name = 'userHideOnlineStatus1618639857000' |  | ||||||
| 
 |  | ||||||
|     public async up(queryRunner: QueryRunner): Promise<void> { |  | ||||||
| 			await queryRunner.query(`ALTER TABLE "user" ADD "hideOnlineStatus" boolean NOT NULL DEFAULT false`); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     public async down(queryRunner: QueryRunner): Promise<void> { |  | ||||||
|         await queryRunner.query(`ALTER TABLE "user" DROP COLUMN "hideOnlineStatus"`); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
| } |  | ||||||
|  | @ -1,14 +0,0 @@ | ||||||
| import {MigrationInterface, QueryRunner} from "typeorm"; |  | ||||||
| 
 |  | ||||||
| export class ad21620364649428 implements MigrationInterface { |  | ||||||
|     name = 'ad21620364649428' |  | ||||||
| 
 |  | ||||||
|     public async up(queryRunner: QueryRunner): Promise<void> { |  | ||||||
|         await queryRunner.query(`ALTER TABLE "ad" ADD "ratio" integer NOT NULL DEFAULT '1'`); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     public async down(queryRunner: QueryRunner): Promise<void> { |  | ||||||
|         await queryRunner.query(`ALTER TABLE "ad" DROP COLUMN "ratio"`); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
| } |  | ||||||
|  | @ -1,16 +0,0 @@ | ||||||
| import {MigrationInterface, QueryRunner} from "typeorm"; |  | ||||||
| 
 |  | ||||||
| export class addNoteIndexes1621479946000 implements MigrationInterface { |  | ||||||
|     name = 'addNoteIndexes1621479946000' |  | ||||||
| 
 |  | ||||||
|     public async up(queryRunner: QueryRunner): Promise<void> { |  | ||||||
|         await queryRunner.query(`CREATE INDEX "IDX_NOTE_MENTIONS" ON "note" USING gin ("mentions")`, undefined); |  | ||||||
| 				await queryRunner.query(`CREATE INDEX "IDX_NOTE_VISIBLE_USER_IDS" ON "note" USING gin ("visibleUserIds")`, undefined); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     public async down(queryRunner: QueryRunner): Promise<void> { |  | ||||||
|         await queryRunner.query(`DROP INDEX "IDX_NOTE_MENTIONS"`, undefined); |  | ||||||
| 				await queryRunner.query(`DROP INDEX "IDX_NOTE_VISIBLE_USER_IDS"`, undefined); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
| } |  | ||||||
|  | @ -1,13 +0,0 @@ | ||||||
| import {MigrationInterface, QueryRunner} from "typeorm"; |  | ||||||
| 
 |  | ||||||
| export class userProfileDescriptionLength1622679304522 implements MigrationInterface { |  | ||||||
| 	name = 'userProfileDescriptionLength1622679304522'; |  | ||||||
| 
 |  | ||||||
| 	public async up(queryRunner: QueryRunner): Promise<void> { |  | ||||||
| 		await queryRunner.query(`ALTER TABLE "user_profile" ALTER COLUMN "description" TYPE character varying(2048)`, undefined); |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	public async down(queryRunner: QueryRunner): Promise<void> { |  | ||||||
| 		await queryRunner.query(`ALTER TABLE "user_profile" ALTER COLUMN "description" TYPE character varying(1024)`, undefined); |  | ||||||
| 	} |  | ||||||
| } |  | ||||||
|  | @ -1,12 +0,0 @@ | ||||||
| import {MigrationInterface, QueryRunner} from "typeorm"; |  | ||||||
| 
 |  | ||||||
| export class logMessageLength1622681548499 implements MigrationInterface { |  | ||||||
| 	name = 'logMessageLength1622681548499'; |  | ||||||
| 	public async up(queryRunner: QueryRunner): Promise<void> { |  | ||||||
| 		await queryRunner.query(`ALTER TABLE "log" ALTER COLUMN "message" TYPE character varying(2048)`, undefined); |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	public async down(queryRunner: QueryRunner): Promise<void> { |  | ||||||
| 		await queryRunner.query(`ALTER TABLE "log" ALTER COLUMN "message" TYPE character varying(1024)`, undefined); |  | ||||||
| 	} |  | ||||||
| } |  | ||||||
|  | @ -1,14 +0,0 @@ | ||||||
| import {MigrationInterface, QueryRunner} from "typeorm"; |  | ||||||
| 
 |  | ||||||
| export class deeplIntegration1629024377804 implements MigrationInterface { |  | ||||||
|     name = 'deeplIntegration1629024377804' |  | ||||||
| 
 |  | ||||||
|     public async up(queryRunner: QueryRunner): Promise<void> { |  | ||||||
|         await queryRunner.query(`ALTER TABLE "meta" ADD "deeplAuthKey" character varying(128)`); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     public async down(queryRunner: QueryRunner): Promise<void> { |  | ||||||
|         await queryRunner.query(`ALTER TABLE "meta" DROP COLUMN "deeplAuthKey"`); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
| } |  | ||||||
|  | @ -1,14 +0,0 @@ | ||||||
| import {MigrationInterface, QueryRunner} from "typeorm"; |  | ||||||
| 
 |  | ||||||
| export class fixChannelUserId1629288472000 implements MigrationInterface { |  | ||||||
|     name = 'fixChannelUserId1629288472000' |  | ||||||
| 
 |  | ||||||
|     public async up(queryRunner: QueryRunner): Promise<void> { |  | ||||||
|         await queryRunner.query(`ALTER TABLE "channel" ALTER COLUMN "userId" DROP NOT NULL;`); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     public async down(queryRunner: QueryRunner): Promise<void> { |  | ||||||
|         await queryRunner.query(`ALTER TABLE "channel" ALTER COLUMN "userId" SET NOT NULL;`); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
| } |  | ||||||
|  | @ -1,15 +0,0 @@ | ||||||
| import {MigrationInterface, QueryRunner} from "typeorm"; |  | ||||||
| 
 |  | ||||||
| export class isUserDeleted1629512953000 implements MigrationInterface { |  | ||||||
|     name = 'isUserDeleted1629512953000' |  | ||||||
| 
 |  | ||||||
|     public async up(queryRunner: QueryRunner): Promise<void> { |  | ||||||
|         await queryRunner.query(`ALTER TABLE "user" ADD "isDeleted" boolean NOT NULL DEFAULT false`); |  | ||||||
|         await queryRunner.query(`COMMENT ON COLUMN "user"."isDeleted" IS 'Whether the User is deleted.'`); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     public async down(queryRunner: QueryRunner): Promise<void> { |  | ||||||
|         await queryRunner.query(`ALTER TABLE "user" DROP COLUMN "isDeleted"`); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
| } |  | ||||||
|  | @ -1,14 +0,0 @@ | ||||||
| import {MigrationInterface, QueryRunner} from "typeorm"; |  | ||||||
| 
 |  | ||||||
| export class deeplIntegration21629778475000 implements MigrationInterface { |  | ||||||
|     name = 'deeplIntegration21629778475000' |  | ||||||
| 
 |  | ||||||
|     public async up(queryRunner: QueryRunner): Promise<void> { |  | ||||||
|         await queryRunner.query(`ALTER TABLE "meta" ADD "deeplIsPro" boolean NOT NULL DEFAULT false`); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     public async down(queryRunner: QueryRunner): Promise<void> { |  | ||||||
|         await queryRunner.query(`ALTER TABLE "meta" DROP COLUMN "deeplIsPro"`); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
| } |  | ||||||
|  | @ -1,14 +0,0 @@ | ||||||
| import {MigrationInterface, QueryRunner} from "typeorm"; |  | ||||||
| 
 |  | ||||||
| export class emailRequiredForSignup1633068642000 implements MigrationInterface { |  | ||||||
|     name = 'emailRequiredForSignup1633068642000' |  | ||||||
| 
 |  | ||||||
|     public async up(queryRunner: QueryRunner): Promise<void> { |  | ||||||
|         await queryRunner.query(`ALTER TABLE "meta" ADD "emailRequiredForSignup" boolean NOT NULL DEFAULT false`); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     public async down(queryRunner: QueryRunner): Promise<void> { |  | ||||||
|         await queryRunner.query(`ALTER TABLE "meta" DROP COLUMN "emailRequiredForSignup"`); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
| } |  | ||||||
|  | @ -1,14 +0,0 @@ | ||||||
| import {MigrationInterface, QueryRunner} from "typeorm"; |  | ||||||
| 
 |  | ||||||
| export class userPublicReactions1634486652000 implements MigrationInterface { |  | ||||||
|     name = 'userPublicReactions1634486652000' |  | ||||||
| 
 |  | ||||||
|     public async up(queryRunner: QueryRunner): Promise<void> { |  | ||||||
| 			await queryRunner.query(`ALTER TABLE "user_profile" ADD "publicReactions" boolean NOT NULL DEFAULT false`); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     public async down(queryRunner: QueryRunner): Promise<void> { |  | ||||||
|         await queryRunner.query(`ALTER TABLE "user_profile" DROP COLUMN "publicReactions"`); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
| } |  | ||||||
|  | @ -1,13 +0,0 @@ | ||||||
| import {MigrationInterface, QueryRunner} from "typeorm"; |  | ||||||
| 
 |  | ||||||
| export class deleteLog1634902659689 implements MigrationInterface { |  | ||||||
|     name = 'deleteLog1634902659689' |  | ||||||
| 
 |  | ||||||
|     public async up(queryRunner: QueryRunner): Promise<void> { |  | ||||||
| 			await queryRunner.query(`DROP TABLE "log"`); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     public async down(queryRunner: QueryRunner): Promise<void> { |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
| } |  | ||||||
							
								
								
									
										243
									
								
								package.json
									
										
									
									
									
								
							
							
						
						|  | @ -1,261 +1,50 @@ | ||||||
| { | { | ||||||
| 	"name": "misskey", | 	"name": "misskey", | ||||||
| 	"version": "12.95.0", | 	"version": "12.96.0", | ||||||
| 	"codename": "indigo", | 	"codename": "indigo", | ||||||
| 	"repository": { | 	"repository": { | ||||||
| 		"type": "git", | 		"type": "git", | ||||||
| 		"url": "https://github.com/misskey-dev/misskey.git" | 		"url": "https://github.com/misskey-dev/misskey.git" | ||||||
| 	}, | 	}, | ||||||
| 	"main": "./index.js", |  | ||||||
| 	"private": true, | 	"private": true, | ||||||
| 	"scripts": { | 	"scripts": { | ||||||
| 		"start": "node --experimental-json-modules ./index.js", | 		"postinstall": "node ./scripts/install-packages.js", | ||||||
| 		"start:test": "cross-env NODE_ENV=test node --experimental-json-modules ./index.js", | 		"build": "node ./scripts/build.js", | ||||||
|  | 		"start": "cd packages/backend && node --experimental-json-modules ./built/index.js", | ||||||
|  | 		"start:test": "cd packages/backend && cross-env NODE_ENV=test node --experimental-json-modules ./built/index.js", | ||||||
| 		"init": "npm run migrate", | 		"init": "npm run migrate", | ||||||
| 		"ormconfig": "node ./built/ormconfig.js", | 		"ormconfig": "node ./packages/backend/ormconfig.js", | ||||||
| 		"migrate": "ts-node ./node_modules/typeorm/cli.js migration:run", | 		"migrate": "cd packages/backend && npx typeorm migration:run", | ||||||
| 		"migrateandstart": "npm run migrate && npm run start", | 		"migrateandstart": "npm run migrate && npm run start", | ||||||
| 		"build": "npm run build-webpack && npm run build-ts && npm run build-gulp", | 		"gulp": "gulp build", | ||||||
| 		"build-webpack": "webpack", |  | ||||||
| 		"build-ts": "tsc -p src/tsconfig.json || echo done. && tsc-alias -p src/tsconfig.json", |  | ||||||
| 		"build-gulp": "gulp build", |  | ||||||
| 		"watch": "concurrently \"npm:watch-*\"", | 		"watch": "concurrently \"npm:watch-*\"", | ||||||
| 		"watch-webpack": "webpack --watch", | 		"watch-webpack": "webpack --watch", | ||||||
| 		"watch-ts": "tsc -w -p src/tsconfig.json && tsc-alias -w -p src/tsconfig.json", | 		"watch-ts": "tsc -w -p packages/tsconfig.json && tsc-alias -w -p packages/tsconfig.json", | ||||||
| 		"watch-gulp": "gulp watch", | 		"watch-gulp": "gulp watch", | ||||||
| 		"clean": "gulp clean", | 		"lint": "node ./scripts/lint.js", | ||||||
| 		"cleanall": "gulp cleanall", |  | ||||||
| 		"lint": "tslint 'src/**/*.ts'", |  | ||||||
| 		"cy:open": "cypress open", | 		"cy:open": "cypress open", | ||||||
| 		"cy:run": "cypress run", | 		"cy:run": "cypress run", | ||||||
| 		"e2e": "start-server-and-test start:test http://localhost:61812 cy:run", | 		"e2e": "start-server-and-test start:test http://localhost:61812 cy:run", | ||||||
| 		"mocha": "cross-env TS_NODE_FILES=true TS_NODE_TRANSPILE_ONLY=true TS_NODE_PROJECT=\"./test/tsconfig.json\" mocha", | 		"mocha": "cd packages/backend && cross-env TS_NODE_FILES=true TS_NODE_TRANSPILE_ONLY=true TS_NODE_PROJECT=\"./test/tsconfig.json\" npx mocha", | ||||||
| 		"test": "npm run mocha", | 		"test": "npm run mocha", | ||||||
| 		"format": "gulp format" | 		"format": "gulp format", | ||||||
| 	}, | 		"clean": "node ./scripts/clean.js" | ||||||
| 	"resolutions": { |  | ||||||
| 		"chokidar": "^3.3.1", |  | ||||||
| 		"lodash": "^4.17.21" |  | ||||||
| 	}, | 	}, | ||||||
| 	"dependencies": { | 	"dependencies": { | ||||||
| 		"@discordapp/twemoji": "13.1.0", |  | ||||||
| 		"@elastic/elasticsearch": "7.11.0", |  | ||||||
| 		"@koa/cors": "3.1.0", |  | ||||||
| 		"@koa/multer": "3.0.0", |  | ||||||
| 		"@koa/router": "9.0.1", |  | ||||||
| 		"@sentry/browser": "5.29.2", |  | ||||||
| 		"@sentry/tracing": "5.29.2", |  | ||||||
| 		"@sinonjs/fake-timers": "7.1.2", |  | ||||||
| 		"@syuilo/aiscript": "0.11.1", |  | ||||||
| 		"@types/bcryptjs": "2.4.2", |  | ||||||
| 		"@types/bull": "3.15.5", |  | ||||||
| 		"@types/cbor": "6.0.0", |  | ||||||
| 		"@types/dateformat": "3.0.1", |  | ||||||
| 		"@types/escape-regexp": "0.0.0", |  | ||||||
| 		"@types/glob": "7.2.0", |  | ||||||
| 		"@types/gulp": "4.0.9", | 		"@types/gulp": "4.0.9", | ||||||
| 		"@types/gulp-rename": "2.0.1", | 		"@types/gulp-rename": "2.0.1", | ||||||
| 		"@types/is-url": "1.2.30", | 		"execa": "5.1.1", | ||||||
| 		"@types/js-yaml": "4.0.4", |  | ||||||
| 		"@types/jsdom": "16.2.13", |  | ||||||
| 		"@types/jsonld": "1.5.6", |  | ||||||
| 		"@types/katex": "0.11.1", |  | ||||||
| 		"@types/koa": "2.13.4", |  | ||||||
| 		"@types/koa-bodyparser": "4.3.3", |  | ||||||
| 		"@types/koa-cors": "0.0.2", |  | ||||||
| 		"@types/koa-favicon": "2.0.21", |  | ||||||
| 		"@types/koa-logger": "3.1.2", |  | ||||||
| 		"@types/koa-mount": "4.0.1", |  | ||||||
| 		"@types/koa-send": "4.1.3", |  | ||||||
| 		"@types/koa-views": "7.0.0", |  | ||||||
| 		"@types/koa__cors": "3.0.3", |  | ||||||
| 		"@types/koa__multer": "2.0.4", |  | ||||||
| 		"@types/koa__router": "8.0.8", |  | ||||||
| 		"@types/markdown-it": "12.2.3", |  | ||||||
| 		"@types/matter-js": "0.17.6", |  | ||||||
| 		"@types/mocha": "8.2.3", |  | ||||||
| 		"@types/node": "16.11.4", |  | ||||||
| 		"@types/node-fetch": "2.5.12", |  | ||||||
| 		"@types/nodemailer": "6.4.4", |  | ||||||
| 		"@types/nprogress": "0.2.0", |  | ||||||
| 		"@types/oauth": "0.9.1", |  | ||||||
| 		"@types/parse5": "6.0.2", |  | ||||||
| 		"@types/parsimmon": "1.10.6", |  | ||||||
| 		"@types/portscanner": "2.1.1", |  | ||||||
| 		"@types/pug": "2.0.5", |  | ||||||
| 		"@types/punycode": "2.1.0", |  | ||||||
| 		"@types/qrcode": "1.4.1", |  | ||||||
| 		"@types/random-seed": "0.3.3", |  | ||||||
| 		"@types/ratelimiter": "3.4.2", |  | ||||||
| 		"@types/redis": "2.8.32", |  | ||||||
| 		"@types/rename": "1.0.4", |  | ||||||
| 		"@types/request-stats": "3.0.0", |  | ||||||
| 		"@types/rimraf": "3.0.2", |  | ||||||
| 		"@types/seedrandom": "2.4.28", |  | ||||||
| 		"@types/sharp": "0.29.2", |  | ||||||
| 		"@types/sinonjs__fake-timers": "6.0.4", |  | ||||||
| 		"@types/speakeasy": "2.0.6", |  | ||||||
| 		"@types/throttle-debounce": "2.1.0", |  | ||||||
| 		"@types/tinycolor2": "1.4.3", |  | ||||||
| 		"@types/tmp": "0.2.2", |  | ||||||
| 		"@types/uuid": "8.3.1", |  | ||||||
| 		"@types/web-push": "3.3.2", |  | ||||||
| 		"@types/webpack": "5.28.0", |  | ||||||
| 		"@types/webpack-stream": "3.2.12", |  | ||||||
| 		"@types/websocket": "1.0.4", |  | ||||||
| 		"@types/ws": "8.2.0", |  | ||||||
| 		"@typescript-eslint/parser": "5.1.0", |  | ||||||
| 		"@vue/compiler-sfc": "3.2.20", |  | ||||||
| 		"abort-controller": "3.0.0", |  | ||||||
| 		"autobind-decorator": "2.4.0", |  | ||||||
| 		"autosize": "4.0.4", |  | ||||||
| 		"autwh": "0.1.0", |  | ||||||
| 		"aws-sdk": "2.1013.0", |  | ||||||
| 		"bcryptjs": "2.4.3", |  | ||||||
| 		"blurhash": "1.1.4", |  | ||||||
| 		"broadcast-channel": "4.2.0", |  | ||||||
| 		"bull": "3.29.3", |  | ||||||
| 		"cacheable-lookup": "6.0.3", |  | ||||||
| 		"cafy": "15.2.1", |  | ||||||
| 		"cbor": "8.0.2", |  | ||||||
| 		"chalk": "4.1.2", |  | ||||||
| 		"chart.js": "3.6.0", |  | ||||||
| 		"chartjs-adapter-date-fns": "2.0.0", |  | ||||||
| 		"chartjs-plugin-zoom": "1.1.1", |  | ||||||
| 		"cli-highlight": "2.1.11", |  | ||||||
| 		"compare-versions": "3.6.0", |  | ||||||
| 		"concurrently": "6.3.0", |  | ||||||
| 		"content-disposition": "0.5.3", |  | ||||||
| 		"crc-32": "1.2.0", |  | ||||||
| 		"css-loader": "6.4.0", |  | ||||||
| 		"cssnano": "5.0.8", |  | ||||||
| 		"date-fns": "2.25.0", |  | ||||||
| 		"dateformat": "4.5.1", |  | ||||||
| 		"escape-regexp": "0.0.1", |  | ||||||
| 		"eslint": "8.1.0", |  | ||||||
| 		"eslint-plugin-vue": "7.20.0", |  | ||||||
| 		"eventemitter3": "4.0.7", |  | ||||||
| 		"feed": "4.2.2", |  | ||||||
| 		"file-type": "16.5.3", |  | ||||||
| 		"fluent-ffmpeg": "2.1.2", |  | ||||||
| 		"glob": "7.2.0", |  | ||||||
| 		"got": "11.8.2", |  | ||||||
| 		"gulp": "4.0.2", | 		"gulp": "4.0.2", | ||||||
| 		"gulp-cssnano": "2.1.3", | 		"gulp-cssnano": "2.1.3", | ||||||
| 		"gulp-rename": "2.0.0", | 		"gulp-rename": "2.0.0", | ||||||
| 		"gulp-replace": "1.1.3", | 		"gulp-replace": "1.1.3", | ||||||
| 		"gulp-terser": "2.1.0", | 		"gulp-terser": "2.1.0" | ||||||
| 		"gulp-tslint": "8.1.4", |  | ||||||
| 		"hpagent": "0.1.2", |  | ||||||
| 		"http-signature": "1.3.5", |  | ||||||
| 		"idb-keyval": "5.1.3", |  | ||||||
| 		"insert-text-at-cursor": "0.3.0", |  | ||||||
| 		"ip-cidr": "3.0.4", |  | ||||||
| 		"is-svg": "4.3.1", |  | ||||||
| 		"js-yaml": "4.1.0", |  | ||||||
| 		"jsdom": "16.7.0", |  | ||||||
| 		"json5": "2.2.0", |  | ||||||
| 		"json5-loader": "4.0.1", |  | ||||||
| 		"jsonld": "5.2.0", |  | ||||||
| 		"jsrsasign": "8.0.20", |  | ||||||
| 		"katex": "0.13.18", |  | ||||||
| 		"koa": "2.13.4", |  | ||||||
| 		"koa-bodyparser": "4.3.0", |  | ||||||
| 		"koa-favicon": "2.1.0", |  | ||||||
| 		"koa-json-body": "5.3.0", |  | ||||||
| 		"koa-logger": "3.2.1", |  | ||||||
| 		"koa-mount": "4.0.0", |  | ||||||
| 		"koa-send": "5.0.1", |  | ||||||
| 		"koa-slow": "2.1.0", |  | ||||||
| 		"koa-views": "7.0.1", |  | ||||||
| 		"langmap": "0.0.16", |  | ||||||
| 		"markdown-it": "12.2.0", |  | ||||||
| 		"markdown-it-anchor": "7.1.0", |  | ||||||
| 		"matter-js": "0.17.1", |  | ||||||
| 		"mfm-js": "0.20.0", |  | ||||||
| 		"misskey-js": "0.0.8", |  | ||||||
| 		"mocha": "8.4.0", |  | ||||||
| 		"ms": "2.1.3", |  | ||||||
| 		"multer": "1.4.3", |  | ||||||
| 		"nested-property": "4.0.0", |  | ||||||
| 		"node-fetch": "2.6.1", |  | ||||||
| 		"nodemailer": "6.7.0", |  | ||||||
| 		"os-utils": "0.0.14", |  | ||||||
| 		"parse5": "6.0.1", |  | ||||||
| 		"pg": "8.7.1", |  | ||||||
| 		"photoswipe": "git://github.com/dimsemenov/photoswipe#v5-beta", |  | ||||||
| 		"portscanner": "2.2.0", |  | ||||||
| 		"postcss": "8.3.11", |  | ||||||
| 		"postcss-loader": "6.2.0", |  | ||||||
| 		"prismjs": "1.25.0", |  | ||||||
| 		"private-ip": "2.3.0", |  | ||||||
| 		"probe-image-size": "7.2.1", |  | ||||||
| 		"promise-limit": "2.7.0", |  | ||||||
| 		"pug": "3.0.2", |  | ||||||
| 		"punycode": "2.1.1", |  | ||||||
| 		"pureimage": "0.3.5", |  | ||||||
| 		"qrcode": "1.4.4", |  | ||||||
| 		"random-seed": "0.3.0", |  | ||||||
| 		"ratelimiter": "3.4.1", |  | ||||||
| 		"re2": "1.16.0", |  | ||||||
| 		"redis": "3.1.2", |  | ||||||
| 		"redis-lock": "0.1.4", |  | ||||||
| 		"reflect-metadata": "0.1.13", |  | ||||||
| 		"rename": "1.0.4", |  | ||||||
| 		"request-stats": "3.0.0", |  | ||||||
| 		"require-all": "3.0.0", |  | ||||||
| 		"rimraf": "3.0.2", |  | ||||||
| 		"rndstr": "1.0.0", |  | ||||||
| 		"s-age": "1.1.2", |  | ||||||
| 		"sass": "1.43.3", |  | ||||||
| 		"sass-loader": "12.2.0", |  | ||||||
| 		"seedrandom": "3.0.5", |  | ||||||
| 		"sharp": "0.29.2", |  | ||||||
| 		"speakeasy": "2.0.0", |  | ||||||
| 		"strict-event-emitter-types": "2.0.0", |  | ||||||
| 		"stringz": "2.1.0", |  | ||||||
| 		"style-loader": "3.3.1", |  | ||||||
| 		"summaly": "2.4.1", |  | ||||||
| 		"syslog-pro": "1.0.0", |  | ||||||
| 		"systeminformation": "5.9.8", |  | ||||||
| 		"syuilo-password-strength": "0.0.1", |  | ||||||
| 		"textarea-caret": "3.1.0", |  | ||||||
| 		"three": "0.117.1", |  | ||||||
| 		"throttle-debounce": "3.0.1", |  | ||||||
| 		"tinycolor2": "1.4.2", |  | ||||||
| 		"tmp": "0.2.1", |  | ||||||
| 		"ts-loader": "9.2.6", |  | ||||||
| 		"ts-node": "10.4.0", |  | ||||||
| 		"tsc-alias": "1.3.10", |  | ||||||
| 		"tsconfig-paths": "3.11.0", |  | ||||||
| 		"tslint": "6.1.3", |  | ||||||
| 		"tslint-sonarts": "1.9.0", |  | ||||||
| 		"twemoji-parser": "13.1.0", |  | ||||||
| 		"typeorm": "0.2.38", |  | ||||||
| 		"typescript": "4.4.4", |  | ||||||
| 		"ulid": "2.3.0", |  | ||||||
| 		"uuid": "8.3.2", |  | ||||||
| 		"v-debounce": "0.1.2", |  | ||||||
| 		"vanilla-tilt": "1.7.2", |  | ||||||
| 		"vue": "3.2.20", |  | ||||||
| 		"vue-loader": "16.7.0", |  | ||||||
| 		"vue-prism-editor": "2.0.0-alpha.2", |  | ||||||
| 		"vue-router": "4.0.5", |  | ||||||
| 		"vue-style-loader": "4.1.3", |  | ||||||
| 		"vue-svg-loader": "0.17.0-beta.2", |  | ||||||
| 		"vuedraggable": "4.0.1", |  | ||||||
| 		"web-push": "3.4.5", |  | ||||||
| 		"webpack": "5.59.1", |  | ||||||
| 		"webpack-cli": "4.9.1", |  | ||||||
| 		"websocket": "1.0.34", |  | ||||||
| 		"ws": "8.2.3", |  | ||||||
| 		"xev": "2.0.1" |  | ||||||
| 	}, | 	}, | ||||||
| 	"devDependencies": { | 	"devDependencies": { | ||||||
| 		"@redocly/openapi-core": "1.0.0-beta.54", | 		"@redocly/openapi-core": "1.0.0-beta.54", | ||||||
| 		"@types/fluent-ffmpeg": "2.1.17", | 		"@types/fluent-ffmpeg": "2.1.17", | ||||||
| 		"cross-env": "7.0.3", | 		"cross-env": "7.0.3", | ||||||
| 		"cypress": "8.5.0", | 		"cypress": "9.0.0", | ||||||
| 		"start-server-and-test": "1.14.0" | 		"start-server-and-test": "1.14.0" | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
|  |  | ||||||
							
								
								
									
										4
									
								
								packages/backend/.eslintignore
									
										
									
									
									
										Normal file
									
								
							
							
						
						|  | @ -0,0 +1,4 @@ | ||||||
|  | node_modules | ||||||
|  | /built | ||||||
|  | /.eslintrc.js | ||||||
|  | /@types/**/* | ||||||
							
								
								
									
										64
									
								
								packages/backend/.eslintrc.js
									
										
									
									
									
										Normal file
									
								
							
							
						
						|  | @ -0,0 +1,64 @@ | ||||||
|  | module.exports = { | ||||||
|  | 	root: true, | ||||||
|  | 	parser: '@typescript-eslint/parser', | ||||||
|  | 	parserOptions: { | ||||||
|  | 		tsconfigRootDir: __dirname, | ||||||
|  | 		project: ['./tsconfig.json'], | ||||||
|  | 	}, | ||||||
|  | 	plugins: [ | ||||||
|  | 		'@typescript-eslint', | ||||||
|  | 		'import' | ||||||
|  | 	], | ||||||
|  | 	extends: [ | ||||||
|  | 		'eslint:recommended', | ||||||
|  | 		'plugin:@typescript-eslint/recommended', | ||||||
|  | 		'plugin:import/recommended', | ||||||
|  | 		'plugin:import/typescript' | ||||||
|  | 	], | ||||||
|  | 	rules: { | ||||||
|  | 		'indent': ['warn', 'tab', { | ||||||
|  | 			'SwitchCase': 1, | ||||||
|  | 			'MemberExpression': 'off', | ||||||
|  | 			'flatTernaryExpressions': true, | ||||||
|  | 			'ArrayExpression': 'first', | ||||||
|  | 			'ObjectExpression': 'first', | ||||||
|  | 		}], | ||||||
|  | 		'eol-last': ['error', 'always'], | ||||||
|  | 		'semi': ['error', 'always'], | ||||||
|  | 		'quotes': ['warn', 'single'], | ||||||
|  | 		'comma-dangle': ['warn', 'always-multiline'], | ||||||
|  | 		'keyword-spacing': ['error', { | ||||||
|  | 			'before': true, | ||||||
|  | 			'after': true, | ||||||
|  | 		}], | ||||||
|  | 		/* TODO: path aliasを使わないとwarnする | ||||||
|  | 		'no-restricted-imports': ['warn', { | ||||||
|  | 			'patterns': [ | ||||||
|  | 			] | ||||||
|  | 		}], | ||||||
|  | 		*/ | ||||||
|  | 		'no-multi-spaces': ['error'], | ||||||
|  | 		'no-var': ['error'], | ||||||
|  | 		'prefer-arrow-callback': ['error'], | ||||||
|  | 		'no-throw-literal': ['warn'], | ||||||
|  | 		'no-param-reassign': ['warn'], | ||||||
|  | 		'no-constant-condition': ['warn'], | ||||||
|  | 		'no-empty-pattern': ['warn'], | ||||||
|  | 		'no-async-promise-executor': ['off'], | ||||||
|  | 		'no-useless-escape': ['off'], | ||||||
|  | 		'no-multi-spaces': ['warn'], | ||||||
|  | 		'no-control-regex': ['warn'], | ||||||
|  | 		'no-empty': ['warn'], | ||||||
|  | 		'no-inner-declarations': ['off'], | ||||||
|  | 		'no-sparse-arrays': ['off'], | ||||||
|  | 		'@typescript-eslint/no-var-requires': ['warn'], | ||||||
|  | 		'@typescript-eslint/no-inferrable-types': ['warn'], | ||||||
|  | 		'@typescript-eslint/no-empty-function': ['off'], | ||||||
|  | 		'@typescript-eslint/no-non-null-assertion': ['off'], | ||||||
|  | 		'@typescript-eslint/no-misused-promises': ['error', { | ||||||
|  | 			'checksVoidReturn': false, | ||||||
|  | 		}], | ||||||
|  | 		'import/no-unresolved': ['off'], | ||||||
|  | 		'import/no-default-export': ['warn'], | ||||||
|  | 	}, | ||||||
|  | }; | ||||||
							
								
								
									
										2
									
								
								packages/backend/.npmrc
									
										
									
									
									
										Normal file
									
								
							
							
						
						|  | @ -0,0 +1,2 @@ | ||||||
|  | save-exact = true | ||||||
|  | package-lock = false | ||||||
							
								
								
									
										1
									
								
								packages/backend/.yarnrc
									
										
									
									
									
										Normal file
									
								
							
							
						
						|  | @ -0,0 +1 @@ | ||||||
|  | network-timeout 600000 | ||||||
|  | @ -171,7 +171,7 @@ declare module 'jsrsasign' { | ||||||
| 
 | 
 | ||||||
| 		public static getTLVbyList(h: ASN1S, currentIndex: Idx<ASN1ObjectString>, nthList: Mutable<Nth[]>, checkingTag?: string): ASN1TLV; | 		public static getTLVbyList(h: ASN1S, currentIndex: Idx<ASN1ObjectString>, nthList: Mutable<Nth[]>, checkingTag?: string): ASN1TLV; | ||||||
| 
 | 
 | ||||||
| 		// tslint:disable-next-line:bool-param-default
 | 		// eslint:disable-next-line:bool-param-default
 | ||||||
| 		public static getVbyList(h: ASN1S, currentIndex: Idx<ASN1ObjectString>, nthList: Mutable<Nth[]>, checkingTag?: string, removeUnusedbits?: boolean): ASN1V; | 		public static getVbyList(h: ASN1S, currentIndex: Idx<ASN1ObjectString>, nthList: Mutable<Nth[]>, checkingTag?: string, removeUnusedbits?: boolean): ASN1V; | ||||||
| 
 | 
 | ||||||
| 		public static hextooidstr(hex: ASN1OIDV): OID; | 		public static hextooidstr(hex: ASN1OIDV): OID; | ||||||
| Before Width: | Height: | Size: 5.4 KiB After Width: | Height: | Size: 5.4 KiB | 
| Before Width: | Height: | Size: 9.6 KiB After Width: | Height: | Size: 9.6 KiB | 
| Before Width: | Height: | Size: 88 KiB After Width: | Height: | Size: 88 KiB | 
| Before Width: | Height: | Size: 9.1 KiB After Width: | Height: | Size: 9.1 KiB | 
| Before Width: | Height: | Size: 7.5 KiB After Width: | Height: | Size: 7.5 KiB | 
| Before Width: | Height: | Size: 20 KiB After Width: | Height: | Size: 20 KiB | 
| Before Width: | Height: | Size: 18 KiB After Width: | Height: | Size: 18 KiB | 
| Before Width: | Height: | Size: 3.4 KiB After Width: | Height: | Size: 3.4 KiB | 
|  | @ -1,8 +1,7 @@ | ||||||
| import {MigrationInterface, QueryRunner} from "typeorm"; | "use strict"; | ||||||
| 
 | Object.defineProperty(exports, "__esModule", { value: true }); | ||||||
| export class Init1000000000000 implements MigrationInterface { | class Init1000000000000 { | ||||||
| 
 |     async up(queryRunner) { | ||||||
|     public async up(queryRunner: QueryRunner): Promise<any> { |  | ||||||
|         await queryRunner.query(`CREATE TYPE "log_level_enum" AS ENUM('error', 'warning', 'info', 'success', 'debug')`); |         await queryRunner.query(`CREATE TYPE "log_level_enum" AS ENUM('error', 'warning', 'info', 'success', 'debug')`); | ||||||
|         await queryRunner.query(`CREATE TABLE "log" ("id" character varying(32) NOT NULL, "createdAt" TIMESTAMP WITH TIME ZONE NOT NULL, "domain" character varying(64) array NOT NULL DEFAULT '{}'::varchar[], "level" "log_level_enum" NOT NULL, "worker" character varying(8) NOT NULL, "machine" character varying(128) NOT NULL, "message" character varying(1024) NOT NULL, "data" jsonb NOT NULL DEFAULT '{}', CONSTRAINT "PK_350604cbdf991d5930d9e618fbd" PRIMARY KEY ("id"))`); |         await queryRunner.query(`CREATE TABLE "log" ("id" character varying(32) NOT NULL, "createdAt" TIMESTAMP WITH TIME ZONE NOT NULL, "domain" character varying(64) array NOT NULL DEFAULT '{}'::varchar[], "level" "log_level_enum" NOT NULL, "worker" character varying(8) NOT NULL, "machine" character varying(128) NOT NULL, "message" character varying(1024) NOT NULL, "data" jsonb NOT NULL DEFAULT '{}', CONSTRAINT "PK_350604cbdf991d5930d9e618fbd" PRIMARY KEY ("id"))`); | ||||||
|         await queryRunner.query(`CREATE INDEX "IDX_8e4eb51a35d81b64dda28eed0a" ON "log" ("createdAt") `); |         await queryRunner.query(`CREATE INDEX "IDX_8e4eb51a35d81b64dda28eed0a" ON "log" ("createdAt") `); | ||||||
|  | @ -241,8 +240,7 @@ export class Init1000000000000 implements MigrationInterface { | ||||||
|         await queryRunner.query(`ALTER TABLE "user_publickey" ADD CONSTRAINT "FK_10c146e4b39b443ede016f6736d" FOREIGN KEY ("userId") REFERENCES "user"("id") ON DELETE CASCADE ON UPDATE NO ACTION`); |         await queryRunner.query(`ALTER TABLE "user_publickey" ADD CONSTRAINT "FK_10c146e4b39b443ede016f6736d" FOREIGN KEY ("userId") REFERENCES "user"("id") ON DELETE CASCADE ON UPDATE NO ACTION`); | ||||||
|         await queryRunner.query(`ALTER TABLE "user_profile" ADD CONSTRAINT "FK_51cb79b5555effaf7d69ba1cff9" FOREIGN KEY ("userId") REFERENCES "user"("id") ON DELETE CASCADE ON UPDATE NO ACTION`); |         await queryRunner.query(`ALTER TABLE "user_profile" ADD CONSTRAINT "FK_51cb79b5555effaf7d69ba1cff9" FOREIGN KEY ("userId") REFERENCES "user"("id") ON DELETE CASCADE ON UPDATE NO ACTION`); | ||||||
|     } |     } | ||||||
| 
 |     async down(queryRunner) { | ||||||
|     public async down(queryRunner: QueryRunner): Promise<any> { |  | ||||||
|         await queryRunner.query(`ALTER TABLE "user_profile" DROP CONSTRAINT "FK_51cb79b5555effaf7d69ba1cff9"`); |         await queryRunner.query(`ALTER TABLE "user_profile" DROP CONSTRAINT "FK_51cb79b5555effaf7d69ba1cff9"`); | ||||||
|         await queryRunner.query(`ALTER TABLE "user_publickey" DROP CONSTRAINT "FK_10c146e4b39b443ede016f6736d"`); |         await queryRunner.query(`ALTER TABLE "user_publickey" DROP CONSTRAINT "FK_10c146e4b39b443ede016f6736d"`); | ||||||
|         await queryRunner.query(`ALTER TABLE "user_keypair" DROP CONSTRAINT "FK_f4853eb41ab722fe05f81cedeb6"`); |         await queryRunner.query(`ALTER TABLE "user_keypair" DROP CONSTRAINT "FK_f4853eb41ab722fe05f81cedeb6"`); | ||||||
|  | @ -481,5 +479,5 @@ export class Init1000000000000 implements MigrationInterface { | ||||||
|         await queryRunner.query(`DROP TABLE "log"`); |         await queryRunner.query(`DROP TABLE "log"`); | ||||||
|         await queryRunner.query(`DROP TYPE "log_level_enum"`); |         await queryRunner.query(`DROP TYPE "log_level_enum"`); | ||||||
|     } |     } | ||||||
| 
 |  | ||||||
| } | } | ||||||
|  | exports.Init1000000000000 = Init1000000000000; | ||||||
|  | @ -1,8 +1,7 @@ | ||||||
| import {MigrationInterface, QueryRunner} from "typeorm"; | "use strict"; | ||||||
| 
 | Object.defineProperty(exports, "__esModule", { value: true }); | ||||||
| export class Pages1556348509290 implements MigrationInterface { | class Pages1556348509290 { | ||||||
| 
 |     async up(queryRunner) { | ||||||
|     public async up(queryRunner: QueryRunner): Promise<any> { |  | ||||||
|         await queryRunner.query(`CREATE TYPE "page_visibility_enum" AS ENUM('public', 'followers', 'specified')`); |         await queryRunner.query(`CREATE TYPE "page_visibility_enum" AS ENUM('public', 'followers', 'specified')`); | ||||||
|         await queryRunner.query(`CREATE TABLE "page" ("id" character varying(32) NOT NULL, "createdAt" TIMESTAMP WITH TIME ZONE NOT NULL, "updatedAt" TIMESTAMP WITH TIME ZONE NOT NULL, "title" character varying(256) NOT NULL, "name" character varying(256) NOT NULL, "summary" character varying(256), "alignCenter" boolean NOT NULL, "font" character varying(32) NOT NULL, "userId" character varying(32) NOT NULL, "eyeCatchingImageId" character varying(32), "content" jsonb NOT NULL DEFAULT '[]', "variables" jsonb NOT NULL DEFAULT '[]', "visibility" "page_visibility_enum" NOT NULL, "visibleUserIds" character varying(32) array NOT NULL DEFAULT '{}'::varchar[], CONSTRAINT "PK_742f4117e065c5b6ad21b37ba1f" PRIMARY KEY ("id"))`); |         await queryRunner.query(`CREATE TABLE "page" ("id" character varying(32) NOT NULL, "createdAt" TIMESTAMP WITH TIME ZONE NOT NULL, "updatedAt" TIMESTAMP WITH TIME ZONE NOT NULL, "title" character varying(256) NOT NULL, "name" character varying(256) NOT NULL, "summary" character varying(256), "alignCenter" boolean NOT NULL, "font" character varying(32) NOT NULL, "userId" character varying(32) NOT NULL, "eyeCatchingImageId" character varying(32), "content" jsonb NOT NULL DEFAULT '[]', "variables" jsonb NOT NULL DEFAULT '[]', "visibility" "page_visibility_enum" NOT NULL, "visibleUserIds" character varying(32) array NOT NULL DEFAULT '{}'::varchar[], CONSTRAINT "PK_742f4117e065c5b6ad21b37ba1f" PRIMARY KEY ("id"))`); | ||||||
|         await queryRunner.query(`CREATE INDEX "IDX_fbb4297c927a9b85e9cefa2eb1" ON "page" ("createdAt") `); |         await queryRunner.query(`CREATE INDEX "IDX_fbb4297c927a9b85e9cefa2eb1" ON "page" ("createdAt") `); | ||||||
|  | @ -14,8 +13,7 @@ export class Pages1556348509290 implements MigrationInterface { | ||||||
|         await queryRunner.query(`ALTER TABLE "page" ADD CONSTRAINT "FK_ae1d917992dd0c9d9bbdad06c4a" FOREIGN KEY ("userId") REFERENCES "user"("id") ON DELETE CASCADE ON UPDATE NO ACTION`); |         await queryRunner.query(`ALTER TABLE "page" ADD CONSTRAINT "FK_ae1d917992dd0c9d9bbdad06c4a" FOREIGN KEY ("userId") REFERENCES "user"("id") ON DELETE CASCADE ON UPDATE NO ACTION`); | ||||||
|         await queryRunner.query(`ALTER TABLE "page" ADD CONSTRAINT "FK_3126dd7c502c9e4d7597ef7ef10" FOREIGN KEY ("eyeCatchingImageId") REFERENCES "drive_file"("id") ON DELETE CASCADE ON UPDATE NO ACTION`); |         await queryRunner.query(`ALTER TABLE "page" ADD CONSTRAINT "FK_3126dd7c502c9e4d7597ef7ef10" FOREIGN KEY ("eyeCatchingImageId") REFERENCES "drive_file"("id") ON DELETE CASCADE ON UPDATE NO ACTION`); | ||||||
|     } |     } | ||||||
| 
 |     async down(queryRunner) { | ||||||
|     public async down(queryRunner: QueryRunner): Promise<any> { |  | ||||||
|         await queryRunner.query(`ALTER TABLE "page" DROP CONSTRAINT "FK_3126dd7c502c9e4d7597ef7ef10"`); |         await queryRunner.query(`ALTER TABLE "page" DROP CONSTRAINT "FK_3126dd7c502c9e4d7597ef7ef10"`); | ||||||
|         await queryRunner.query(`ALTER TABLE "page" DROP CONSTRAINT "FK_ae1d917992dd0c9d9bbdad06c4a"`); |         await queryRunner.query(`ALTER TABLE "page" DROP CONSTRAINT "FK_ae1d917992dd0c9d9bbdad06c4a"`); | ||||||
|         await queryRunner.query(`DROP INDEX "IDX_2133ef8317e4bdb839c0dcbf13"`); |         await queryRunner.query(`DROP INDEX "IDX_2133ef8317e4bdb839c0dcbf13"`); | ||||||
|  | @ -27,5 +25,5 @@ export class Pages1556348509290 implements MigrationInterface { | ||||||
|         await queryRunner.query(`DROP TABLE "page"`); |         await queryRunner.query(`DROP TABLE "page"`); | ||||||
|         await queryRunner.query(`DROP TYPE "page_visibility_enum"`); |         await queryRunner.query(`DROP TYPE "page_visibility_enum"`); | ||||||
|     } |     } | ||||||
| 
 |  | ||||||
| } | } | ||||||
|  | exports.Pages1556348509290 = Pages1556348509290; | ||||||
|  | @ -1,16 +1,14 @@ | ||||||
| import {MigrationInterface, QueryRunner} from "typeorm"; | "use strict"; | ||||||
| 
 | Object.defineProperty(exports, "__esModule", { value: true }); | ||||||
| export class UserProfile1556746559567 implements MigrationInterface { | class UserProfile1556746559567 { | ||||||
| 
 |     async up(queryRunner) { | ||||||
|     public async up(queryRunner: QueryRunner): Promise<any> { |  | ||||||
|         await queryRunner.query(`ALTER TABLE "user_profile" ALTER COLUMN "githubId" TYPE VARCHAR(64) USING "githubId"::VARCHAR(64)`); |         await queryRunner.query(`ALTER TABLE "user_profile" ALTER COLUMN "githubId" TYPE VARCHAR(64) USING "githubId"::VARCHAR(64)`); | ||||||
|         await queryRunner.query(`ALTER TABLE "user_profile" ALTER COLUMN "discordExpiresDate" TYPE VARCHAR(64) USING "discordExpiresDate"::VARCHAR(64)`); |         await queryRunner.query(`ALTER TABLE "user_profile" ALTER COLUMN "discordExpiresDate" TYPE VARCHAR(64) USING "discordExpiresDate"::VARCHAR(64)`); | ||||||
|     } |     } | ||||||
| 
 |     async down(queryRunner) { | ||||||
|     public async down(queryRunner: QueryRunner): Promise<any> { |  | ||||||
|         await queryRunner.query(`UPDATE "user_profile" SET github = FALSE, discord = FALSE`); |         await queryRunner.query(`UPDATE "user_profile" SET github = FALSE, discord = FALSE`); | ||||||
|         await queryRunner.query(`ALTER TABLE "user_profile" ALTER COLUMN "githubId" TYPE INTEGER USING NULL`); |         await queryRunner.query(`ALTER TABLE "user_profile" ALTER COLUMN "githubId" TYPE INTEGER USING NULL`); | ||||||
|         await queryRunner.query(`ALTER TABLE "user_profile" ALTER COLUMN "discordExpiresDate" TYPE INTEGER USING NULL`); |         await queryRunner.query(`ALTER TABLE "user_profile" ALTER COLUMN "discordExpiresDate" TYPE INTEGER USING NULL`); | ||||||
|     } |     } | ||||||
| 
 |  | ||||||
| } | } | ||||||
|  | exports.UserProfile1556746559567 = UserProfile1556746559567; | ||||||
							
								
								
									
										11
									
								
								packages/backend/migration/1557476068003-PinnedUsers.js
									
										
									
									
									
										Normal file
									
								
							
							
						
						|  | @ -0,0 +1,11 @@ | ||||||
|  | "use strict"; | ||||||
|  | Object.defineProperty(exports, "__esModule", { value: true }); | ||||||
|  | class PinnedUsers1557476068003 { | ||||||
|  |     async up(queryRunner) { | ||||||
|  |         await queryRunner.query(`ALTER TABLE "meta" ADD "pinnedUsers" character varying(256) array NOT NULL DEFAULT '{}'::varchar[]`); | ||||||
|  |     } | ||||||
|  |     async down(queryRunner) { | ||||||
|  |         await queryRunner.query(`ALTER TABLE "meta" DROP COLUMN "pinnedUsers"`); | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | exports.PinnedUsers1557476068003 = PinnedUsers1557476068003; | ||||||
|  | @ -1,16 +1,15 @@ | ||||||
| import {MigrationInterface, QueryRunner} from "typeorm"; | "use strict"; | ||||||
| 
 | Object.defineProperty(exports, "__esModule", { value: true }); | ||||||
| export class AddSomeUrls1557761316509 implements MigrationInterface { | class AddSomeUrls1557761316509 { | ||||||
| 
 |     async up(queryRunner) { | ||||||
|     public async up(queryRunner: QueryRunner): Promise<any> { |  | ||||||
|         await queryRunner.query(`ALTER TABLE "meta" ADD "ToSUrl" character varying(512)`); |         await queryRunner.query(`ALTER TABLE "meta" ADD "ToSUrl" character varying(512)`); | ||||||
|         await queryRunner.query(`ALTER TABLE "meta" ADD "repositoryUrl" character varying(512) NOT NULL DEFAULT 'https://github.com/misskey-dev/misskey'`); |         await queryRunner.query(`ALTER TABLE "meta" ADD "repositoryUrl" character varying(512) NOT NULL DEFAULT 'https://github.com/misskey-dev/misskey'`); | ||||||
|         await queryRunner.query(`ALTER TABLE "meta" ADD "feedbackUrl" character varying(512) DEFAULT 'https://github.com/misskey-dev/misskey/issues/new'`); |         await queryRunner.query(`ALTER TABLE "meta" ADD "feedbackUrl" character varying(512) DEFAULT 'https://github.com/misskey-dev/misskey/issues/new'`); | ||||||
|     } |     } | ||||||
| 
 |     async down(queryRunner) { | ||||||
|     public async down(queryRunner: QueryRunner): Promise<any> { |  | ||||||
|         await queryRunner.query(`ALTER TABLE "meta" DROP COLUMN "feedbackUrl"`); |         await queryRunner.query(`ALTER TABLE "meta" DROP COLUMN "feedbackUrl"`); | ||||||
|         await queryRunner.query(`ALTER TABLE "meta" DROP COLUMN "repositoryUrl"`); |         await queryRunner.query(`ALTER TABLE "meta" DROP COLUMN "repositoryUrl"`); | ||||||
|         await queryRunner.query(`ALTER TABLE "meta" DROP COLUMN "ToSUrl"`); |         await queryRunner.query(`ALTER TABLE "meta" DROP COLUMN "ToSUrl"`); | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  | exports.AddSomeUrls1557761316509 = AddSomeUrls1557761316509; | ||||||
|  | @ -1,8 +1,7 @@ | ||||||
| import {MigrationInterface, QueryRunner} from "typeorm"; | "use strict"; | ||||||
| 
 | Object.defineProperty(exports, "__esModule", { value: true }); | ||||||
| export class ObjectStorageSetting1557932705754 implements MigrationInterface { | class ObjectStorageSetting1557932705754 { | ||||||
| 
 |     async up(queryRunner) { | ||||||
|     public async up(queryRunner: QueryRunner): Promise<any> { |  | ||||||
|         await queryRunner.query(`ALTER TABLE "meta" ADD "useObjectStorage" boolean NOT NULL DEFAULT false`); |         await queryRunner.query(`ALTER TABLE "meta" ADD "useObjectStorage" boolean NOT NULL DEFAULT false`); | ||||||
|         await queryRunner.query(`ALTER TABLE "meta" ADD "objectStorageBucket" character varying(512)`); |         await queryRunner.query(`ALTER TABLE "meta" ADD "objectStorageBucket" character varying(512)`); | ||||||
|         await queryRunner.query(`ALTER TABLE "meta" ADD "objectStoragePrefix" character varying(512)`); |         await queryRunner.query(`ALTER TABLE "meta" ADD "objectStoragePrefix" character varying(512)`); | ||||||
|  | @ -14,8 +13,7 @@ export class ObjectStorageSetting1557932705754 implements MigrationInterface { | ||||||
|         await queryRunner.query(`ALTER TABLE "meta" ADD "objectStoragePort" integer`); |         await queryRunner.query(`ALTER TABLE "meta" ADD "objectStoragePort" integer`); | ||||||
|         await queryRunner.query(`ALTER TABLE "meta" ADD "objectStorageUseSSL" boolean NOT NULL DEFAULT true`); |         await queryRunner.query(`ALTER TABLE "meta" ADD "objectStorageUseSSL" boolean NOT NULL DEFAULT true`); | ||||||
|     } |     } | ||||||
| 
 |     async down(queryRunner) { | ||||||
|     public async down(queryRunner: QueryRunner): Promise<any> { |  | ||||||
|         await queryRunner.query(`ALTER TABLE "meta" DROP COLUMN "objectStorageUseSSL"`); |         await queryRunner.query(`ALTER TABLE "meta" DROP COLUMN "objectStorageUseSSL"`); | ||||||
|         await queryRunner.query(`ALTER TABLE "meta" DROP COLUMN "objectStoragePort"`); |         await queryRunner.query(`ALTER TABLE "meta" DROP COLUMN "objectStoragePort"`); | ||||||
|         await queryRunner.query(`ALTER TABLE "meta" DROP COLUMN "objectStorageSecretKey"`); |         await queryRunner.query(`ALTER TABLE "meta" DROP COLUMN "objectStorageSecretKey"`); | ||||||
|  | @ -27,5 +25,5 @@ export class ObjectStorageSetting1557932705754 implements MigrationInterface { | ||||||
|         await queryRunner.query(`ALTER TABLE "meta" DROP COLUMN "objectStorageBucket"`); |         await queryRunner.query(`ALTER TABLE "meta" DROP COLUMN "objectStorageBucket"`); | ||||||
|         await queryRunner.query(`ALTER TABLE "meta" DROP COLUMN "useObjectStorage"`); |         await queryRunner.query(`ALTER TABLE "meta" DROP COLUMN "useObjectStorage"`); | ||||||
|     } |     } | ||||||
| 
 |  | ||||||
| } | } | ||||||
|  | exports.ObjectStorageSetting1557932705754 = ObjectStorageSetting1557932705754; | ||||||