Compare commits
	
		
			44 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | ea60565b0d | ||
|   | a26585dcc7 | ||
|   | 008e5bd24c | ||
|   | ebc6564fbb | ||
|   | 06b5078245 | ||
|   | 68337f95ff | ||
|   | 72e148002a | ||
|   | f0a03f71eb | ||
|   | 6049473e46 | ||
|   | f9f2787dfc | ||
|   | b0a068e269 | ||
|   | dd5546690a | ||
|   | d87b6d38ab | ||
|   | 4069bb170a | ||
|   | 600c009549 | ||
|   | c953a28201 | ||
|   | f6541df42a | ||
|   | a57e9460c8 | ||
|   | c7bcf31105 | ||
|   | a397c040fe | ||
|   | e311d73ffc | ||
|   | 2a3599a14d | ||
|   | b85dc8a658 | ||
|   | 7513123052 | ||
|   | 2526b86ec5 | ||
|   | e45aa0532c | ||
|   | 71fc84e224 | ||
|   | 6b726eea39 | ||
|   | acd4b101e1 | ||
|   | 98b8a94f2b | ||
|   | 7d31bd97ff | ||
|   | 828a2a73c9 | ||
|   | bdc7167cf4 | ||
|   | 45b94086ed | ||
|   | e62bb7cdaf | ||
|   | c5f65d9eeb | ||
|   | 4557856104 | ||
|   | 4a23c36740 | ||
|   | 2553b20130 | ||
|   | 6982faf668 | ||
|   | 4db972318f | ||
|   | 81006566a5 | ||
|   | 6abc053a48 | ||
|   | 03a3c56a54 | 
							
								
								
									
										3
									
								
								.autogen/check_pr.jq
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,3 @@ | ||||
| .[] | ||||
| .head | ||||
| .label | ||||
							
								
								
									
										2
									
								
								.autogen/next_url.jq
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,2 @@ | ||||
| .links | ||||
| .next | ||||
							
								
								
									
										39
									
								
								.autogen/patreon.jq
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,39 @@ | ||||
| ( | ||||
|   .data | | ||||
|   map( | ||||
|     select( | ||||
|       .relationships | ||||
|       .currently_entitled_tiers | ||||
|       .data[] | ||||
|     ) | ||||
|   ) | | ||||
|   map( | ||||
|     .relationships | ||||
|     .user | ||||
|     .data | ||||
|     .id | ||||
|   ) | ||||
| ) as $data | | ||||
| .included | | ||||
| map( | ||||
|   select( | ||||
|     .id as $id | | ||||
|     $data | | ||||
|     contains( | ||||
|       [ | ||||
|         $id | ||||
|       ] | ||||
|     ) | ||||
|   ) | ||||
| ) | | ||||
| map( | ||||
|   .attributes | | ||||
|   [ | ||||
|     .full_name, | ||||
|     .thumb_url, | ||||
|     .url | ||||
|   ] | | ||||
|   @tsv | ||||
| ) | | ||||
| .[] | | ||||
| @text | ||||
							
								
								
									
										87
									
								
								.autogen/update_readme_patreon.sh
									
									
									
									
									
										Executable file
									
								
							
							
						
						| @@ -0,0 +1,87 @@ | ||||
| #!/usr/bin/env bash | ||||
| # __MISSKEY_BEARER_TOKEN= | ||||
| # __MISSKEY_CAMPAIGN_ID= | ||||
| # __MISSKEY_GITHUB_TOKEN= | ||||
| # __MISSKEY_HEAD=syuilo:patch-autogen | ||||
| # __MISSKEY_REPO=syuilo/misskey | ||||
| # __MISSKEY_BRANCH=develop | ||||
| test "$(curl -LSs -w '\n' -- "https://api.github.com/repos/$REPO/pulls?access_token=$__MISSKEY_GITHUB_TOKEN" | jq -r -f check_pr.jq | grep $__MISSKEY_HEAD)" && exit 1 | ||||
| cd "$(dirname $0)/.." && \ | ||||
| touch null.cache && \ | ||||
| rm *.cache && \ | ||||
| git checkout $__MISSKEY_BRANCH && \ | ||||
| git pull origin $__MISSKEY_BRANCH && \ | ||||
| git pull upstream $__MISSKEY_BRANCH && \ | ||||
| git stash && \ | ||||
| git rebase -f upstream/$__MISSKEY_BRANCH && \ | ||||
| git branch patch-autogen && \ | ||||
| git checkout patch-autogen && \ | ||||
| git reset --hard HEAD || \ | ||||
| exit 1 | ||||
| touch patreon.md.cache && \ | ||||
| rm patreon.md.cache && \ | ||||
| echo '<!-- PATREON_START -->' > patreon.md.cache && \ | ||||
| url="https://www.patreon.com/api/oauth2/v2/campaigns/$__MISSKEY_CAMPAIGN_ID/members?include=currently_entitled_tiers,user&fields%5Btier%5D=title&fields%5Buser%5D=full_name,thumb_url,url,hide_pledges" | ||||
| while : | ||||
|  do | ||||
|   touch patreon.raw.cache && \ | ||||
|   rm patreon.raw.cache && \ | ||||
|   curl -LSs -w '\n' -H "Authorization: Bearer $__MISSKEY_BEARER_TOKEN" -- $url > patreon.raw.cache && \ | ||||
|   touch patreon.cache && \ | ||||
|   rm patreon.cache && \ | ||||
|   cat patreon.raw.cache | \ | ||||
|   jq -r -f patreon.jq >> patreon.cache && \ | ||||
|   echo '<table><tr>' >> patreon.md.cache && \ | ||||
|   cat patreon.cache | \ | ||||
|   awk -F'\t' '{print $2,$1}' | \ | ||||
|   sed -e 's/ /\\" alt=\\"/' | \ | ||||
|   xargs -I% echo '<td><img src="%" width="100"></td>' >> patreon.md.cache && \ | ||||
|   echo '</tr><tr>' >> patreon.md.cache && \ | ||||
|   cat patreon.cache | \ | ||||
|   awk -F'\t' '{print $3,$1}' | \ | ||||
|   sed -e 's/ /\\">/' | \ | ||||
|   xargs -I% echo '<td><a href="%</a></td>' >> patreon.md.cache && \ | ||||
|   echo '</tr></table>' >> patreon.md.cache || \ | ||||
|   exit 1 | ||||
|   new_url="$(cat patreon.raw.cache | jq -r -f next_url.jq)" | ||||
|   test "$new_url" = 'null' && \ | ||||
|   break || \ | ||||
|   URL="$url" | ||||
| done | ||||
| ignore= && \ | ||||
| echo -e "\n**Last updated:** $(date -uR | sed 's/\+0000/UTC/')\n<!-- PATREON_END -->" >> patreon.md.cache && \ | ||||
| touch README.md && \ | ||||
| touch .autogen/README.md && \ | ||||
| rm .autogen/README.md && \ | ||||
| mv README.md .autogen/README.md && \ | ||||
| cat .autogen/README.md | while IFS= read line; | ||||
|  do | ||||
|   if [[ -z "$ignore" ]] | ||||
|    then | ||||
|     if [[ "$line" = '<!-- PATREON_START -->' ]] | ||||
|      then | ||||
|       ignore='PATREON_INSIDE' | ||||
|      else | ||||
|       echo "$line" >> README.md | ||||
|     fi | ||||
|    else | ||||
|     if [[ "$LINE" = '<!-- PATREON_END -->' ]] | ||||
|      then | ||||
|       ignore= | ||||
|       cat patreon.md.cache >> README.md | ||||
|     fi | ||||
|   fi | ||||
| done | ||||
| cat patreon.md.cache | ||||
| touch null.cache && \ | ||||
| rm *.cache && \ | ||||
| diff .autogen/README.md README.md > diff.cache | ||||
| cat diff.cache && \ | ||||
| test 4 -lt $(cat diff.cache | wc -l) && \ | ||||
| git add README.md && \ | ||||
| git commit -m 'Update README.md [AUTOGEN]' && \ | ||||
| git push -f origin patch-autogen && \ | ||||
| curl -LSs -w '\n' -X POST -d '{"title":"[AUTOMATED] Update README.md","body":"*This pull request was created by a tool.*","head":"'$__MISSKEY_HEAD'","base":"'$__MISSKEY_BRANCH'"}' -- "https://api.github.com/repos/$__MISSKEY_REPO/pulls?access_token=$__MISSKEY_GITHUB_TOKEN" | ||||
| git stash | ||||
| git checkout $__MISSKEY_BRANCH | ||||
| git branch -D patch-autogen | ||||
							
								
								
									
										194
									
								
								.circleci/config.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,194 @@ | ||||
| version: 2.1 | ||||
|  | ||||
| executors: | ||||
|   default: | ||||
|     working_directory: /tmp/workspace | ||||
|     docker: | ||||
|       - image: misskey/ci:latest | ||||
|       - image: circleci/mongo:latest | ||||
|   with-redis: | ||||
|     working_directory: /tmp/workspace | ||||
|     docker: | ||||
|       - image: misskey/ci:latest | ||||
|       - image: circleci/mongo:latest | ||||
|       - image: circleci/redis:latest | ||||
|   docker: | ||||
|     working_directory: /tmp/workspace | ||||
|     docker: | ||||
|       - image: docker:latest | ||||
|  | ||||
| jobs: | ||||
|   build: | ||||
|     executor: default | ||||
|     steps: | ||||
|       - checkout | ||||
|       - run: | ||||
|           name: Ensure yarn.lock | ||||
|           command: | | ||||
|             touch yarn.lock | ||||
|       - restore_cache: | ||||
|           name: Restore npm package caches | ||||
|           keys: | ||||
|             - yarn-v1-arch-{{ arch }}-env-{{ .Environment.variableName }}-package-{{ checksum "package.json" }}-lock-{{ checksum "yarn.lock" }} | ||||
|             - yarn-v1-arch-{{ arch }}-env-{{ .Environment.variableName }}-package-{{ checksum "package.json" }}- | ||||
|             - yarn-v1-arch-{{ arch }}-env-{{ .Environment.variableName }}- | ||||
|             - yarn-v1-arch-{{ arch }}- | ||||
|             - yarn-v1- | ||||
|       - run: | ||||
|           name: Install Dependencies | ||||
|           command: | | ||||
|             yarn install | ||||
|       - run: | ||||
|           name: Configure | ||||
|           command: | | ||||
|             cp .circleci/misskey/default.yml .config | ||||
|             cp .circleci/misskey/test.yml .config | ||||
|       - run: | ||||
|           name: Build | ||||
|           command: | | ||||
|             yarn build | ||||
|             touch yarn.lock | ||||
|       - save_cache: | ||||
|           name: Cache npm packages | ||||
|           key: yarn-v1-arch-{{ arch }}-env-{{ .Environment.variableName }}-package-{{ checksum "package.json" }}-lock-{{ checksum "yarn.lock" }} | ||||
|           paths: | ||||
|             - node_modules | ||||
|       - persist_to_workspace: | ||||
|           root: . | ||||
|           paths: | ||||
|             - . | ||||
|   test: | ||||
|     parameters: | ||||
|       executor: | ||||
|         type: string | ||||
|         default: "default" | ||||
|       without_redis: | ||||
|         type: boolean | ||||
|         default: false | ||||
|     executor: <<parameters.executor>> | ||||
|     steps: | ||||
|       - attach_workspace: | ||||
|           at: /tmp/workspace | ||||
|       - when: | ||||
|           condition: <<parameters.without_redis>> | ||||
|           steps: | ||||
|             - run: | ||||
|                 name: Configure | ||||
|                 command: | | ||||
|                   mv .config/test.yml .config/test_redis.yml | ||||
|                   touch .config/test.yml | ||||
|                   cat .config/test_redis.yml | while IFS= read line; do if [[ "$line" = '# __REDIS__' ]]; then break; else echo "$line" >> .config/test.yml; fi; done | ||||
|       - run: | ||||
|           name: Test | ||||
|           command: | | ||||
|             yarn test | ||||
|             touch yarn.lock | ||||
|       - save_cache: | ||||
|           name: Cache npm packages | ||||
|           key: yarn-v1-arch-{{ arch }}-env-{{ .Environment.variableName }}-package-{{ checksum "package.json" }}-lock-{{ checksum "yarn.lock" }} | ||||
|           paths: | ||||
|             - node_modules | ||||
|   docker: | ||||
|     parameters: | ||||
|       with_deploy: | ||||
|         type: boolean | ||||
|         default: false | ||||
|     executor: docker | ||||
|     steps: | ||||
|       - checkout | ||||
|       - setup_remote_docker | ||||
|       - run: | ||||
|           name: Build | ||||
|           command: | | ||||
|             docker build -t misskey/misskey . | ||||
|       - when: | ||||
|           condition: <<parameters.with_deploy>> | ||||
|           steps: | ||||
|             - run: | ||||
|                 name: Deploy | ||||
|                 command: | | ||||
|                   if [ "$DOCKERHUB_USERNAME$DOCKERHUB_PASSWORD" ] | ||||
|                    then | ||||
|                     apk update && apk add jq | ||||
|                     docker tag misskey/misskey misskey/misskey:$(cat package.json | jq -r .version) | ||||
|                     docker login -u $DOCKERHUB_USERNAME -p $DOCKERHUB_PASSWORD | ||||
|                     docker push misskey/misskey | ||||
|                    else | ||||
|                     echo -e '\033[0;33mAborted deploying to Docker Hub\033[0;39m' | ||||
|                   fi | ||||
|  | ||||
| workflows: | ||||
|   version: 2 | ||||
|   nodejs: | ||||
|     jobs: | ||||
|       - hold: | ||||
|           name: manual-build-trigger | ||||
|           type: approval | ||||
|           filters: | ||||
|             branches: | ||||
|               ignore: master | ||||
|       - build: | ||||
|           name: manual-build | ||||
|           requires: | ||||
|             - manual-build-trigger | ||||
|           filters: | ||||
|             branches: | ||||
|               ignore: master | ||||
|       - build: | ||||
|           name: auto-build | ||||
|           filters: | ||||
|             branches: | ||||
|               only: master | ||||
|       - test: | ||||
|           name: manual-test-with-redis | ||||
|           executor: with-redis | ||||
|           requires: | ||||
|             - manual-build | ||||
|           filters: | ||||
|             branches: | ||||
|               ignore: master | ||||
|       - test: | ||||
|           name: auto-test-without-redis | ||||
|           executor: with-redis | ||||
|           requires: | ||||
|             - auto-build | ||||
|           filters: | ||||
|             branches: | ||||
|               only: master | ||||
|       - test: | ||||
|           name: manual-test-with-redis | ||||
|           without_redis: true | ||||
|           requires: | ||||
|             - manual-build | ||||
|           filters: | ||||
|             branches: | ||||
|               ignore: master | ||||
|       - test: | ||||
|           name: auto-test-without-redis | ||||
|           without_redis: true | ||||
|           requires: | ||||
|             - auto-build | ||||
|           filters: | ||||
|             branches: | ||||
|               only: master | ||||
|   docker: | ||||
|     jobs: | ||||
|       - hold: | ||||
|           name: manual-build-trigger | ||||
|           type: approval | ||||
|           filters: | ||||
|             branches: | ||||
|               ignore: master | ||||
|       - docker: | ||||
|           name: manual-build | ||||
|           requires: | ||||
|             - manual-build-trigger | ||||
|           filters: | ||||
|             branches: | ||||
|               ignore: master | ||||
|       - docker: | ||||
|           name: auto-build | ||||
|           with_deploy: true | ||||
|           filters: | ||||
|             branches: | ||||
|               only: master | ||||
							
								
								
									
										14
									
								
								.circleci/misskey/default.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,14 @@ | ||||
| url: 'http://misskey.local' | ||||
| port: 80 | ||||
| mongodb: | ||||
|   host: localhost | ||||
|   port: 27017 | ||||
|   db: misskey | ||||
|   user: syuilo | ||||
|   pass: '' | ||||
| drive: | ||||
|   storage: 'db' | ||||
| redis: | ||||
|   host: localhost | ||||
|   port: 6379 | ||||
|   pass: '' | ||||
							
								
								
									
										15
									
								
								.circleci/misskey/test.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,15 @@ | ||||
| url: 'http://misskey.local' | ||||
| port: 80 | ||||
| mongodb: | ||||
|   host: localhost | ||||
|   port: 27017 | ||||
|   db: test-misskey | ||||
|   user: admin | ||||
|   pass: '' | ||||
| drive: | ||||
|   storage: 'db' | ||||
| # __REDIS__ | ||||
| redis: | ||||
|   host: localhost | ||||
|   port: 6379 | ||||
|   pass: '' | ||||
| @@ -1,4 +0,0 @@ | ||||
| # db settings | ||||
| POSTGRES_PASSWORD=example-misskey-pass | ||||
| POSTGRES_USER=example-misskey-user | ||||
| POSTGRES_DB=misskey | ||||
| @@ -1,21 +1,13 @@ | ||||
| #━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ | ||||
| # Misskey configuration | ||||
| #━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ | ||||
|  | ||||
| #   ┌─────┐ | ||||
| #───┘ URL └───────────────────────────────────────────────────── | ||||
|  | ||||
| # Final accessible URL seen by a user. | ||||
| url: https://example.tld/ | ||||
|  | ||||
| # ONCE YOU HAVE STARTED THE INSTANCE, DO NOT CHANGE THE | ||||
| # URL SETTINGS AFTER THAT! | ||||
|  | ||||
| #   ┌───────────────────────┐ | ||||
| #───┘ Port and TLS settings └─────────────────────────────────── | ||||
|  | ||||
| ### Port and TLS settings ###################################### | ||||
| # | ||||
| # Misskey requires a reverse proxy to support HTTPS connections. | ||||
| # Misskey supports two deployment options for public. | ||||
| # | ||||
|  | ||||
| # Option 1: With Reverse Proxy | ||||
| # | ||||
| #                 +----- https://example.tld/ ------------+ | ||||
| #   +------+      |+-------------+      +----------------+| | ||||
| @@ -23,127 +15,118 @@ url: https://example.tld/ | ||||
| #   +------+      |+-------------+      +----------------+| | ||||
| #                 +---------------------------------------+ | ||||
| # | ||||
| #   You need to set up a reverse proxy. (e.g. nginx) | ||||
| #   An encrypted connection with HTTPS is highly recommended | ||||
| #   because tokens may be transferred in GET requests. | ||||
| #   You need to setup reverse proxy. (eg. nginx) | ||||
| #   You do not define 'https' section. | ||||
|  | ||||
| # The port that your Misskey server should listen on. | ||||
| port: 3000 | ||||
| # Option 2: Standalone | ||||
| # | ||||
| #                 +- https://example.tld/ -+ | ||||
| #   +------+      |   +---------------+    | | ||||
| #   | User | ---> |   | Misskey (443) |    | | ||||
| #   +------+      |   +---------------+    | | ||||
| #                 +------------------------+ | ||||
| # | ||||
| #   You need to run Misskey as root. | ||||
| #   You need to set Certificate in 'https' section. | ||||
|  | ||||
| #   ┌──────────────────────────┐ | ||||
| #───┘ PostgreSQL configuration └──────────────────────────────── | ||||
| # To use option 1, uncomment below line. | ||||
| # port: 3000    # A port that your Misskey server should listen. | ||||
|  | ||||
| db: | ||||
| # To use option 2, uncomment below lines. | ||||
| # port: 443 | ||||
| # | ||||
| # https: | ||||
| #   # path for certification | ||||
| #   key: /etc/letsencrypt/live/example.tld/privkey.pem | ||||
| #   cert: /etc/letsencrypt/live/example.tld/fullchain.pem | ||||
|  | ||||
| ################################################################ | ||||
|  | ||||
|  | ||||
| mongodb: | ||||
|   host: localhost | ||||
|   port: 5432 | ||||
|  | ||||
|   # Database name | ||||
|   port: 27017 | ||||
|   db: misskey | ||||
|  | ||||
|   # Auth | ||||
|   user: example-misskey-user | ||||
|   pass: example-misskey-pass | ||||
|  | ||||
|   # Whether disable Caching queries | ||||
|   #disableCache: true | ||||
| drive: | ||||
|   storage: 'db' | ||||
|  | ||||
|   # Extra Connection options | ||||
|   #extra: | ||||
|   #  ssl: true | ||||
| # OR | ||||
|  | ||||
| #   ┌─────────────────────┐ | ||||
| #───┘ Redis configuration └───────────────────────────────────── | ||||
| #drive: | ||||
| #  storage: 'minio' | ||||
| #  bucket: | ||||
| #  prefix: | ||||
| #  config: | ||||
| #    endPoint: | ||||
| #    port: | ||||
| #    useSSL: | ||||
| #    accessKey: | ||||
| #    secretKey: | ||||
|  | ||||
| redis: | ||||
|   host: localhost | ||||
|   port: 6379 | ||||
|   #family: 0  # 0=Both, 4=IPv4, 6=IPv6 | ||||
|   #pass: example-pass | ||||
|   #prefix: example-prefix | ||||
|   #db: 1 | ||||
| # S3/GCS example | ||||
| # | ||||
| # * Replace <endpoint> to | ||||
| #     S3: see https://docs.aws.amazon.com/general/latest/gr/rande.html#s3_region | ||||
| #     GCS: use 'storage.googleapis.com' | ||||
| # | ||||
| # * Replace <region> to | ||||
| #     S3: see https://docs.aws.amazon.com/general/latest/gr/rande.html#s3_region | ||||
| #     GCS: not needed (just delete the region line) | ||||
| # | ||||
| #drive: | ||||
| #  storage: 'minio' | ||||
| #  bucket: bucket-name | ||||
| #  prefix: files | ||||
| #  baseUrl: https://bucket-name.<endpoint> | ||||
| #  config: | ||||
| #    endPoint: <endpoint> | ||||
| #    region: <region> | ||||
| #    useSSL: true | ||||
| #    accessKey: XXX | ||||
| #    secretKey: YYY | ||||
|  | ||||
| #   ┌─────────────────────────────┐ | ||||
| #───┘ Elasticsearch configuration └───────────────────────────── | ||||
| # S3/GCS example (with CDN, custom domain) | ||||
| # | ||||
| #drive: | ||||
| #  storage: 'minio' | ||||
| #  bucket: drive.example.com | ||||
| #  prefix: files | ||||
| #  baseUrl: https://drive.example.com | ||||
| #  config: | ||||
| #    endPoint: <endpoint> | ||||
| #    region: <region> | ||||
| #    useSSL: true | ||||
| #    accessKey: XXX | ||||
| #    secretKey: YYY | ||||
|  | ||||
| # If enabled: | ||||
| #  The first account created is automatically marked as Admin. | ||||
| autoAdmin: true | ||||
|  | ||||
| # | ||||
| # Below settings are optional | ||||
| # | ||||
|  | ||||
| # Redis | ||||
| #redis: | ||||
| #  host: localhost | ||||
| #  port: 6379 | ||||
| #  pass: example-pass | ||||
|  | ||||
| # Elasticsearch | ||||
| #elasticsearch: | ||||
| #  host: localhost | ||||
| #  port: 9200 | ||||
| #  ssl: false | ||||
| #  user:  | ||||
| #  pass:  | ||||
|  | ||||
| #   ┌───────────────┐ | ||||
| #───┘ ID generation └─────────────────────────────────────────── | ||||
|  | ||||
| # You can select the ID generation method. | ||||
| # You don't usually need to change this setting, but you can | ||||
| # change it according to your preferences. | ||||
|  | ||||
| # Available methods: | ||||
| # aid ... Short, Millisecond accuracy | ||||
| # meid ... Similar to ObjectID, Millisecond accuracy | ||||
| # ulid ... Millisecond accuracy | ||||
| # objectid ... This is left for backward compatibility | ||||
|  | ||||
| # ONCE YOU HAVE STARTED THE INSTANCE, DO NOT CHANGE THE | ||||
| # ID SETTINGS AFTER THAT! | ||||
|  | ||||
| id: 'aid' | ||||
|  | ||||
| #   ┌─────────────────────┐ | ||||
| #───┘ Other configuration └───────────────────────────────────── | ||||
| #  pass: null | ||||
|  | ||||
| # Whether disable HSTS | ||||
| #disableHsts: true | ||||
|  | ||||
| # Number of worker processes | ||||
| # Clustering | ||||
| #clusterLimit: 1 | ||||
|  | ||||
| # Job concurrency per worker | ||||
| # deliverJobConcurrency: 128 | ||||
| # inboxJobConcurrency: 16 | ||||
|  | ||||
| # Job rate limiter | ||||
| # deliverJobPerSec: 128 | ||||
| # inboxJobPerSec: 16 | ||||
|  | ||||
| # Job attempts | ||||
| # deliverJobMaxAttempts: 12 | ||||
| # inboxJobMaxAttempts: 8 | ||||
|  | ||||
| # IP address family used for outgoing request (ipv4, ipv6 or dual) | ||||
| #outgoingAddressFamily: ipv4 | ||||
|  | ||||
| # Syslog option | ||||
| #syslog: | ||||
| #  host: localhost | ||||
| #  port: 514 | ||||
|  | ||||
| # Proxy for HTTP/HTTPS | ||||
| #proxy: http://127.0.0.1:3128 | ||||
|  | ||||
| #proxyBypassHosts: [ | ||||
| #  'example.com', | ||||
| #  '192.0.2.8' | ||||
| #] | ||||
|  | ||||
| # Proxy for SMTP/SMTPS | ||||
| #proxySmtp: http://127.0.0.1:3128   # use HTTP/1.1 CONNECT | ||||
| #proxySmtp: socks4://127.0.0.1:1080 # use SOCKS4 | ||||
| #proxySmtp: socks5://127.0.0.1:1080 # use SOCKS5 | ||||
|  | ||||
| # Media Proxy | ||||
| #mediaProxy: https://example.com/proxy | ||||
|  | ||||
| # Proxy remote files (default: false) | ||||
| #proxyRemoteFiles: true | ||||
|  | ||||
| # Sign to ActivityPub GET request (default: false) | ||||
| #signToActivityPubGet: true | ||||
|  | ||||
| #allowedPrivateNetworks: [ | ||||
| #  '127.0.0.1/32' | ||||
| #] | ||||
|  | ||||
| # Upload or download file size limits (bytes) | ||||
| #maxFileSize: 262144000 | ||||
|   | ||||
							
								
								
									
										13
									
								
								.config/mongo_initdb_example.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,13 @@ | ||||
| var user = { | ||||
| 	user: 'example-misskey-user', | ||||
| 	pwd: 'example-misskey-pass', | ||||
| 	roles: [ | ||||
| 	    { | ||||
| 		    role: 'readWrite', | ||||
| 		    db: 'misskey' | ||||
| 	    } | ||||
| 	] | ||||
| }; | ||||
|  | ||||
| db.createUser(user); | ||||
|  | ||||
							
								
								
									
										9
									
								
								.dockerignore
									
									
									
									
									
										
										
										Normal file → Executable file
									
								
							
							
						
						| @@ -1,15 +1,12 @@ | ||||
| .autogen | ||||
| .git | ||||
| .github | ||||
| .travis | ||||
| .vscode | ||||
| .config | ||||
| Dockerfile | ||||
| build/ | ||||
| built/ | ||||
| db/ | ||||
| docker-compose.yml | ||||
| elasticsearch/ | ||||
| node_modules/ | ||||
| mongo/ | ||||
| redis/ | ||||
| files/ | ||||
| misskey-assets/ | ||||
| elasticsearch/ | ||||
|   | ||||
							
								
								
									
										31
									
								
								.eslintrc
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,31 @@ | ||||
| { | ||||
| 	"parserOptions": { | ||||
| 		"parser": "typescript-eslint-parser" | ||||
| 	}, | ||||
| 	"extends": [ | ||||
| 		"eslint:recommended", | ||||
| 		"plugin:vue/recommended" | ||||
| 	], | ||||
| 	"rules": { | ||||
| 		"vue/require-v-for-key": false, | ||||
| 		"vue/max-attributes-per-line": false, | ||||
| 		"vue/html-indent": false, | ||||
| 		"vue/html-self-closing": false, | ||||
| 		"vue/no-unused-vars": false, | ||||
| 		"vue/attributes-order": false, | ||||
| 		"vue/require-prop-types": false, | ||||
| 		"vue/require-default-prop": false, | ||||
| 		"vue/html-closing-bracket-spacing": false, | ||||
| 		"vue/singleline-html-element-content-newline": false, | ||||
| 		"vue/no-v-html": false, | ||||
| 		"no-console": 0, | ||||
| 		"no-unused-vars": 0, | ||||
| 		"no-empty": 0 | ||||
| 	}, | ||||
| 	"globals": { | ||||
| 		"ENV": true, | ||||
| 		"VERSION": true, | ||||
| 		"API": true, | ||||
| 		"LANGS": true | ||||
| 	} | ||||
| } | ||||
							
								
								
									
										6
									
								
								.gitattributes
									
									
									
									
										vendored
									
									
								
							
							
						
						| @@ -1,7 +1,5 @@ | ||||
| *.svg -diff -text | ||||
| *.psd -diff -text | ||||
| *.ai -diff -text | ||||
| *.mqo -diff -text | ||||
| *.glb -diff -text | ||||
| *.blend -diff -text | ||||
| *.afdesign -diff -text | ||||
| yarn.lock -diff -text | ||||
| package-lock.json -diff -text | ||||
|   | ||||
							
								
								
									
										39
									
								
								.github/CODEOWNERS
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,39 @@ | ||||
| # PATH                                          OWNERS | ||||
| /.autogen/                                      @acid-chicken | ||||
| /.circleci/                                     @syuilo @acid-chicken | ||||
| /.config/                                       @syuilo @AyaMorisawa @mei23 @acid-chicken @rinsuki | ||||
| # /.config/mongo_initdb_example.js              @khws4v1 | ||||
| /.github/                                       @syuilo @AyaMorisawa @acid-chicken | ||||
| /.vscode/                                       @acid-chicken | ||||
| /assets/                                        @syuilo # @tamaina | ||||
| /cli/                                           @syuilo | ||||
| /docs/                                          @syuilo | ||||
| /docs/*.en.md                                   @AyaMorisawa # @skid9000 | ||||
| # /docs/*.fr.md                                 @BoFFire | ||||
| # /docs/docker.*.md                             @khws4v1 | ||||
| /locales/                                       @syuilo | ||||
| /src/                                           @syuilo @AyaMorisawa @mei23 @acid-chicken @rinsuki | ||||
| # /src/crypto_key.cc                            @akihikodaki | ||||
| # /src/crypto_key.d.ts                          @akihikodaki | ||||
| /.dockerignore                                  @syuilo # @khws4v1 | ||||
| /.editorconfig                                  @syuilo @AyaMorisawa | ||||
| /.eslintrc                                      @syuilo | ||||
| /.gitattributes                                 @syuilo | ||||
| /.gitignore                                     @syuilo | ||||
| /.npmrc                                         @syuilo | ||||
| /.vsls.json                                     @AyaMorisawa | ||||
| /CHANGELOG.md                                   @syuilo | ||||
| /CODE_OF_CONDUCT.md                             @syuilo | ||||
| /CONTRIBUTING.md                                @syuilo | ||||
| /Dockerfile                                     @syuilo @AyaMorisawa @acid-chicken # @khws4v1 | ||||
| /LICENSE                                        @syuilo | ||||
| /README.md                                      @syuilo @AyaMorisawa @acid-chicken # @nikhiljha | ||||
| # /binding.gyp                                  @akihikodaki | ||||
| /crowdin.yml                                    @syuilo | ||||
| # /docker-compose.yml                           @khws4v1 | ||||
| /gulpfile.ts                                    @syuilo @AyaMorisawa | ||||
| /jsconfig.json                                  @syuilo @AyaMorisawa | ||||
| /package.json                                   @syuilo @AyaMorisawa | ||||
| /tsconfig.json                                  @syuilo @AyaMorisawa | ||||
| /tslint.json                                    @syuilo @AyaMorisawa | ||||
| /webpack.config.ts                              @syuilo @AyaMorisawa | ||||
							
								
								
									
										3
									
								
								.github/FUNDING.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						| @@ -1,3 +0,0 @@ | ||||
| # These are supported funding model platforms | ||||
|  | ||||
| patreon: syuilo | ||||
							
								
								
									
										18
									
								
								.github/ISSUE_TEMPLATE/01_bug-report.md
									
									
									
									
										vendored
									
									
								
							
							
						
						| @@ -7,25 +7,17 @@ assignees: '' | ||||
|  | ||||
| --- | ||||
|  | ||||
| <!-- | ||||
| Thanks for reporting! | ||||
| First, in order to avoid duplicate Issues, please search to see if the problem you found has already been reported. | ||||
| --> | ||||
|  | ||||
| ## 💡 Summary | ||||
|  | ||||
| <!-- Tell us what the bug is --> | ||||
|  | ||||
| ## 🥰 Expected Behavior | ||||
| ## 🙂 Expected Behavior | ||||
|  | ||||
| <!--- Tell us what should happen --> | ||||
|  | ||||
| ## 🤬 Actual Behavior | ||||
| ## ☹️ Actual Behavior | ||||
|  | ||||
| <!-- | ||||
| Tell us what happens instead of the expected behavior. | ||||
| Please include errors from the developer console and/or server log files if you have access to them. | ||||
| --> | ||||
| <!--- Tell us what happens instead of the expected behavior --> | ||||
|  | ||||
| ## 📝 Steps to Reproduce | ||||
|  | ||||
| @@ -36,7 +28,3 @@ Please include errors from the developer console and/or server log files if you | ||||
| ## 📌 Environment | ||||
|  | ||||
| <!-- Tell us where on the platform it happens --> | ||||
|  | ||||
| Misskey version: | ||||
| Your OS: | ||||
| Your browser: | ||||
|   | ||||
							
								
								
									
										7
									
								
								.github/ISSUE_TEMPLATE/config.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						| @@ -1,7 +0,0 @@ | ||||
| contact_links: | ||||
|   - name: 👪 Misskey Forum | ||||
|     url: https://forum.misskey.io/ | ||||
|     about: Ask questions and share knowledge | ||||
|   - name: 💬 Misskey official Discord | ||||
|     url: https://discord.gg/Wp8gVStHW3 | ||||
|     about: Chat freely about Misskey | ||||
							
								
								
									
										28
									
								
								.github/PULL_REQUEST_TEMPLATE.md
									
									
									
									
										vendored
									
									
								
							
							
						
						| @@ -1,17 +1,13 @@ | ||||
| <!-- ℹ お読みください / README | ||||
| PRありがとうございます! PRを作成する前に、コントリビューションガイドをご確認ください: | ||||
| Thank you for your PR! Before creating a PR, please check the contribution guide: | ||||
| https://github.com/misskey-dev/misskey/blob/develop/CONTRIBUTING.md | ||||
| --> | ||||
| ## Summary | ||||
|  | ||||
| # What | ||||
| <!-- このPRで何をしたのか? どう変わるのか? --> | ||||
| <!-- What did you do with this PR? How will it change things? --> | ||||
|  | ||||
| # Why | ||||
| <!-- なぜそうするのか? どういう意図なのか? 何が困っているのか? --> | ||||
| <!-- Why do you do it? What are your intentions? What is the problem? --> | ||||
|  | ||||
| # Additional info (optional) | ||||
| <!-- テスト観点など --> | ||||
| <!-- Test perspective, etc --> | ||||
| <!-- | ||||
|   - | ||||
|   - * Please describe your changes here * | ||||
|   - | ||||
|   - If you are going to resolve some issue, please add this context. | ||||
|   - Resolve #ISSUE_NUMBER | ||||
|   - | ||||
|   - If you are going to fix some bug issue, please add this context. | ||||
|   - Fix #ISSUE_NUMBER | ||||
|   - | ||||
|   --> | ||||
|   | ||||
							
								
								
									
										22
									
								
								.github/dependabot.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						| @@ -1,22 +0,0 @@ | ||||
| # To get started with Dependabot version updates, you'll need to specify which | ||||
| # package ecosystems to update and where the package manifests are located. | ||||
| # Please see the documentation for all configuration options: | ||||
| # https://help.github.com/github/administering-a-repository/configuration-options-for-dependency-updates | ||||
|  | ||||
| version: 2 | ||||
| updates: | ||||
| - package-ecosystem: npm | ||||
|   directory: "/" | ||||
|   schedule: | ||||
|     interval: daily | ||||
|   open-pull-requests-limit: 0 | ||||
| - package-ecosystem: npm | ||||
|   directory: "/packages/backend" | ||||
|   schedule: | ||||
|     interval: daily | ||||
|   open-pull-requests-limit: 0 | ||||
| - package-ecosystem: npm | ||||
|   directory: "/packages/client" | ||||
|   schedule: | ||||
|     interval: daily | ||||
|   open-pull-requests-limit: 0 | ||||
							
								
								
									
										12
									
								
								.github/labeler.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						| @@ -1,12 +0,0 @@ | ||||
| '⚙️Server': | ||||
| - packages/backend/**/* | ||||
|  | ||||
| '🖥️Client': | ||||
| - packages/client/**/* | ||||
|  | ||||
| '🧪Test': | ||||
| - cypress/**/* | ||||
| - packages/backend/test/**/* | ||||
|  | ||||
| '‼️ wrong locales': | ||||
| - any: ['locales/*.yml', '!locales/ja-JP.yml'] | ||||
							
								
								
									
										15
									
								
								.github/misskey/test.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						| @@ -1,15 +0,0 @@ | ||||
| url: 'http://misskey.local' | ||||
|  | ||||
| # ローカルでテストするときにポートを被らないようにするためデフォルトのものとは変える(以下同じ) | ||||
| port: 61812 | ||||
|  | ||||
| db: | ||||
|   host: localhost | ||||
|   port: 54312 | ||||
|   db: test-misskey | ||||
|   user: postgres | ||||
|   pass: '' | ||||
| redis: | ||||
|   host: localhost | ||||
|   port: 56312 | ||||
| id: aid | ||||
							
								
								
									
										33
									
								
								.github/workflows/docker-develop.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						| @@ -1,33 +0,0 @@ | ||||
| name: Publish Docker image (develop) | ||||
|  | ||||
| on: | ||||
|   push: | ||||
|     branches: | ||||
|       - develop | ||||
|   workflow_dispatch: | ||||
|  | ||||
| jobs: | ||||
|   push_to_registry: | ||||
|     name: Push Docker image to Docker Hub | ||||
|     runs-on: ubuntu-latest | ||||
|  | ||||
|     steps: | ||||
|       - name: Check out the repo | ||||
|         uses: actions/checkout@v2 | ||||
|       - name: Docker meta | ||||
|         id: meta | ||||
|         uses: docker/metadata-action@v3 | ||||
|         with: | ||||
|           images: misskey/misskey | ||||
|       - name: Log in to Docker Hub | ||||
|         uses: docker/login-action@v1 | ||||
|         with: | ||||
|           username: ${{ secrets.DOCKER_USERNAME }} | ||||
|           password: ${{ secrets.DOCKER_PASSWORD }} | ||||
|       - name: Build and Push to Docker Hub | ||||
|         uses: docker/build-push-action@v2 | ||||
|         with: | ||||
|           context: . | ||||
|           push: true | ||||
|           tags: misskey/misskey:develop | ||||
|           labels: develop | ||||
							
								
								
									
										32
									
								
								.github/workflows/docker.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						| @@ -1,32 +0,0 @@ | ||||
| name: Publish Docker image | ||||
|  | ||||
| on: | ||||
|   release: | ||||
|     types: [published] | ||||
|   workflow_dispatch: | ||||
|  | ||||
| jobs: | ||||
|   push_to_registry: | ||||
|     name: Push Docker image to Docker Hub | ||||
|     runs-on: ubuntu-latest | ||||
|  | ||||
|     steps: | ||||
|       - name: Check out the repo | ||||
|         uses: actions/checkout@v2 | ||||
|       - name: Docker meta | ||||
|         id: meta | ||||
|         uses: docker/metadata-action@v3 | ||||
|         with: | ||||
|           images: misskey/misskey | ||||
|       - name: Log in to Docker Hub | ||||
|         uses: docker/login-action@v1 | ||||
|         with: | ||||
|           username: ${{ secrets.DOCKER_USERNAME }} | ||||
|           password: ${{ secrets.DOCKER_PASSWORD }} | ||||
|       - name: Build and Push to Docker Hub | ||||
|         uses: docker/build-push-action@v2 | ||||
|         with: | ||||
|           context: . | ||||
|           push: true | ||||
|           tags: ${{ steps.meta.outputs.tags }} | ||||
|           labels: ${{ steps.meta.outputs.labels }} | ||||
							
								
								
									
										16
									
								
								.github/workflows/labeler.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						| @@ -1,16 +0,0 @@ | ||||
| name: "Pull Request Labeler" | ||||
| on: | ||||
|   pull_request_target: | ||||
|     branches-ignore: | ||||
|       - 'l10n_develop' | ||||
|  | ||||
| jobs: | ||||
|   triage: | ||||
|     permissions: | ||||
|       contents: read | ||||
|       pull-requests: write | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|     - uses: actions/labeler@v4 | ||||
|       with: | ||||
|         repo-token: "${{ secrets.GITHUB_TOKEN }}" | ||||
							
								
								
									
										39
									
								
								.github/workflows/lint.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						| @@ -1,39 +0,0 @@ | ||||
| name: Lint | ||||
|  | ||||
| on: | ||||
|   push: | ||||
|     branches: | ||||
|       - master | ||||
|       - develop | ||||
|   pull_request: | ||||
|  | ||||
| jobs: | ||||
|   backend: | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|     - uses: actions/checkout@v2 | ||||
|       with: | ||||
|         submodules: true | ||||
|     - uses: actions/setup-node@v3 | ||||
|       with: | ||||
|         node-version: 18.x | ||||
|         cache: 'yarn' | ||||
|         cache-dependency-path: | | ||||
|           packages/backend/yarn.lock | ||||
|     - run: yarn install | ||||
|     - run: yarn --cwd ./packages/backend lint | ||||
|  | ||||
|   client: | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|     - uses: actions/checkout@v2 | ||||
|       with: | ||||
|         submodules: true | ||||
|     - uses: actions/setup-node@v3 | ||||
|       with: | ||||
|         node-version: 18.x | ||||
|         cache: 'yarn' | ||||
|         cache-dependency-path: | | ||||
|           packages/client/yarn.lock | ||||
|     - run: yarn install | ||||
|     - run: yarn --cwd ./packages/client lint | ||||
							
								
								
									
										36
									
								
								.github/workflows/ok-to-test.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						| @@ -1,36 +0,0 @@ | ||||
| # If someone with write access comments "/ok-to-test" on a pull request, emit a repository_dispatch event | ||||
| name: Ok To Test | ||||
|  | ||||
| on: | ||||
|   issue_comment: | ||||
|     types: [created] | ||||
|  | ||||
| jobs: | ||||
|   ok-to-test: | ||||
|     runs-on: ubuntu-latest | ||||
|     # Only run for PRs, not issue comments | ||||
|     if: ${{ github.event.issue.pull_request }} | ||||
|     steps: | ||||
|     # Generate a GitHub App installation access token from an App ID and private key | ||||
|     # To create a new GitHub App: | ||||
|     #   https://developer.github.com/apps/building-github-apps/creating-a-github-app/ | ||||
|     # See app.yml for an example app manifest | ||||
|     - name: Generate token | ||||
|       id: generate_token | ||||
|       uses: tibdex/github-app-token@v1 | ||||
|       with: | ||||
|         app_id: ${{ secrets.DEPLOYBOT_APP_ID }} | ||||
|         private_key: ${{ secrets.DEPLOYBOT_PRIVATE_KEY }} | ||||
|  | ||||
|     - name: Slash Command Dispatch | ||||
|       uses: peter-evans/slash-command-dispatch@v1 | ||||
|       env: | ||||
|         TOKEN: ${{ steps.generate_token.outputs.token }} | ||||
|       with: | ||||
|         token: ${{ env.TOKEN }} # GitHub App installation access token | ||||
|         # token: ${{ secrets.PERSONAL_ACCESS_TOKEN }} # PAT or OAuth token will also work | ||||
|         reaction-token: ${{ secrets.GITHUB_TOKEN }} | ||||
|         issue-type: pull-request | ||||
|         commands: deploy | ||||
|         named-args: true | ||||
|         permission: write | ||||
							
								
								
									
										95
									
								
								.github/workflows/pr-preview-deploy.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						| @@ -1,95 +0,0 @@ | ||||
| # Run secret-dependent integration tests only after /deploy approval | ||||
| on: | ||||
|   pull_request: | ||||
|     types: [opened, reopened, synchronize] | ||||
|   repository_dispatch: | ||||
|     types: [deploy-command] | ||||
|  | ||||
| name: Deploy preview environment | ||||
|  | ||||
| jobs: | ||||
|   # Repo owner has commented /deploy on a (fork-based) pull request | ||||
|   deploy-preview-environment: | ||||
|     runs-on: ubuntu-latest | ||||
|     if: | ||||
|       github.event_name == 'repository_dispatch' && | ||||
|       github.event.client_payload.slash_command.sha != '' && | ||||
|       contains(github.event.client_payload.pull_request.head.sha, github.event.client_payload.slash_command.sha) | ||||
|     steps: | ||||
|     - uses: actions/github-script@v5 | ||||
|       id: check-id | ||||
|       env: | ||||
|         number: ${{ github.event.client_payload.pull_request.number }} | ||||
|         job: ${{ github.job }} | ||||
|       with: | ||||
|         github-token: ${{ secrets.GITHUB_TOKEN }} | ||||
|         result-encoding: string | ||||
|         script: | | ||||
|           const { data: pull } = await github.rest.pulls.get({ | ||||
|             ...context.repo, | ||||
|             pull_number: process.env.number | ||||
|           }); | ||||
|           const ref = pull.head.sha; | ||||
|  | ||||
|           const { data: checks } = await github.rest.checks.listForRef({ | ||||
|             ...context.repo, | ||||
|             ref | ||||
|           }); | ||||
|  | ||||
|           const check = checks.check_runs.filter(c => c.name === process.env.job); | ||||
|  | ||||
|           return check[0].id; | ||||
|  | ||||
|     - uses: actions/github-script@v5 | ||||
|       env: | ||||
|         check_id: ${{ steps.check-id.outputs.result }} | ||||
|         details_url: ${{ github.server_url }}/${{ github.repository }}/runs/${{ github.run_id }} | ||||
|       with: | ||||
|         github-token: ${{ secrets.GITHUB_TOKEN }} | ||||
|         script: | | ||||
|           await github.rest.checks.update({ | ||||
|             ...context.repo, | ||||
|             check_run_id: process.env.check_id, | ||||
|             status: 'in_progress', | ||||
|             details_url: process.env.details_url | ||||
|           }); | ||||
|  | ||||
|     # Check out merge commit | ||||
|     - name: Fork based /deploy checkout | ||||
|       uses: actions/checkout@v2 | ||||
|       with: | ||||
|         ref: 'refs/pull/${{ github.event.client_payload.pull_request.number }}/merge' | ||||
|  | ||||
|     # <insert integration tests needing secrets> | ||||
|     - name: Context | ||||
|       uses: okteto/context@latest | ||||
|       with: | ||||
|         token: ${{ secrets.OKTETO_TOKEN }} | ||||
|  | ||||
|     - name: Deploy preview environment | ||||
|       uses: ikuradon/deploy-preview@latest | ||||
|       env: | ||||
|         GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | ||||
|       with: | ||||
|         name: pr-${{ github.event.client_payload.pull_request.number }}-syuilo | ||||
|         timeout: 15m | ||||
|  | ||||
|     # Update check run called "integration-fork" | ||||
|     - uses: actions/github-script@v5 | ||||
|       id: update-check-run | ||||
|       if: ${{ always() }} | ||||
|       env: | ||||
|         # Conveniently, job.status maps to https://developer.github.com/v3/checks/runs/#update-a-check-run | ||||
|         conclusion: ${{ job.status }} | ||||
|         check_id: ${{ steps.check-id.outputs.result }} | ||||
|       with: | ||||
|         github-token: ${{ secrets.GITHUB_TOKEN }} | ||||
|         script: | | ||||
|           const { data: result } = await github.rest.checks.update({ | ||||
|             ...context.repo, | ||||
|             check_run_id: process.env.check_id, | ||||
|             status: 'completed', | ||||
|             conclusion: process.env.conclusion | ||||
|           }); | ||||
|  | ||||
|           return result; | ||||
							
								
								
									
										21
									
								
								.github/workflows/pr-preview-destroy.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						| @@ -1,21 +0,0 @@ | ||||
| # file: .github/workflows/preview-closed.yaml | ||||
| on: | ||||
|   pull_request: | ||||
|     types: | ||||
|       - closed | ||||
|  | ||||
| name: Destroy preview environment | ||||
|  | ||||
| jobs: | ||||
|   destroy-preview-environment: | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|       - name: Context | ||||
|         uses: okteto/context@latest | ||||
|         with: | ||||
|           token: ${{ secrets.OKTETO_TOKEN }} | ||||
|  | ||||
|       - name: Destroy preview environment | ||||
|         uses: okteto/destroy-preview@latest | ||||
|         with: | ||||
|           name: pr-${{ github.event.number }}-syuilo | ||||
							
								
								
									
										122
									
								
								.github/workflows/test.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						| @@ -1,122 +0,0 @@ | ||||
| name: Test | ||||
|  | ||||
| on: | ||||
|   push: | ||||
|     branches: | ||||
|       - master | ||||
|       - develop | ||||
|   pull_request: | ||||
|  | ||||
| jobs: | ||||
|   mocha: | ||||
|     runs-on: ubuntu-latest | ||||
|  | ||||
|     strategy: | ||||
|       matrix: | ||||
|         node-version: [18.x] | ||||
|  | ||||
|     services: | ||||
|       postgres: | ||||
|         image: postgres:13 | ||||
|         ports: | ||||
|           - 54312:5432 | ||||
|         env: | ||||
|           POSTGRES_DB: test-misskey | ||||
|           POSTGRES_HOST_AUTH_METHOD: trust | ||||
|       redis: | ||||
|         image: redis:6 | ||||
|         ports: | ||||
|           - 56312:6379 | ||||
|  | ||||
|     steps: | ||||
|     - uses: actions/checkout@v2 | ||||
|       with: | ||||
|         submodules: true | ||||
|     - name: Use Node.js ${{ matrix.node-version }} | ||||
|       uses: actions/setup-node@v3 | ||||
|       with: | ||||
|         node-version: ${{ matrix.node-version }} | ||||
|         cache: 'yarn' | ||||
|         cache-dependency-path: | | ||||
|           packages/backend/yarn.lock | ||||
|           packages/client/yarn.lock | ||||
|     - name: Install dependencies | ||||
|       run: yarn install | ||||
|     - name: Check yarn.lock | ||||
|       run: git diff --exit-code yarn.lock | ||||
|     - name: Copy Configure | ||||
|       run: cp .github/misskey/test.yml .config | ||||
|     - name: Build | ||||
|       run: yarn build | ||||
|     - name: Test | ||||
|       run: yarn mocha | ||||
|  | ||||
|   e2e: | ||||
|     runs-on: ubuntu-latest | ||||
|  | ||||
|     strategy: | ||||
|       fail-fast: false | ||||
|       matrix: | ||||
|         node-version: [18.x] | ||||
|         browser: [chrome] | ||||
|  | ||||
|     services: | ||||
|       postgres: | ||||
|         image: postgres:13 | ||||
|         ports: | ||||
|           - 54312:5432 | ||||
|         env: | ||||
|           POSTGRES_DB: test-misskey | ||||
|           POSTGRES_HOST_AUTH_METHOD: trust | ||||
|       redis: | ||||
|         image: redis:6 | ||||
|         ports: | ||||
|           - 56312:6379 | ||||
|  | ||||
|     steps: | ||||
|     - uses: actions/checkout@v2 | ||||
|       with: | ||||
|         submodules: true | ||||
|     # https://github.com/cypress-io/cypress-docker-images/issues/150 | ||||
|     #- name: Install mplayer for FireFox | ||||
|     #  run: sudo apt install mplayer -y | ||||
|     #  if: ${{ matrix.browser == 'firefox' }} | ||||
|     #- uses: browser-actions/setup-firefox@latest | ||||
|     #  if: ${{ matrix.browser == 'firefox' }} | ||||
|     - name: Use Node.js ${{ matrix.node-version }} | ||||
|       uses: actions/setup-node@v3 | ||||
|       with: | ||||
|         node-version: ${{ matrix.node-version }} | ||||
|         cache: 'yarn' | ||||
|         cache-dependency-path: | | ||||
|           packages/backend/yarn.lock | ||||
|           packages/client/yarn.lock | ||||
|     - name: Install dependencies | ||||
|       run: yarn install | ||||
|     - name: Check yarn.lock | ||||
|       run: git diff --exit-code yarn.lock | ||||
|     - name: Copy Configure | ||||
|       run: cp .github/misskey/test.yml .config | ||||
|     - name: Build | ||||
|       run: yarn build | ||||
|     # https://github.com/cypress-io/cypress/issues/4351#issuecomment-559489091 | ||||
|     - name: ALSA Env | ||||
|       run: echo -e 'pcm.!default {\n type hw\n card 0\n}\n\nctl.!default {\n type hw\n card 0\n}' > ~/.asoundrc | ||||
|     - name: Cypress run | ||||
|       uses: cypress-io/github-action@v4 | ||||
|       with: | ||||
|         install: false | ||||
|         start: npm run start:test | ||||
|         wait-on: 'http://localhost:61812' | ||||
|         headless: false | ||||
|         browser: ${{ matrix.browser }} | ||||
|     - uses: actions/upload-artifact@v2 | ||||
|       if: failure() | ||||
|       with: | ||||
|         name: ${{ matrix.browser }}-cypress-screenshots | ||||
|         path: cypress/screenshots | ||||
|     - uses: actions/upload-artifact@v2 | ||||
|       if: always() | ||||
|       with: | ||||
|         name: ${{ matrix.browser }}-cypress-videos | ||||
|         path: cypress/videos | ||||
							
								
								
									
										36
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						| @@ -1,44 +1,22 @@ | ||||
| # Visual Studio Code | ||||
| /.vscode | ||||
| !/.vscode/extensions.json | ||||
|  | ||||
| # Intelij-IDEA | ||||
| /.idea | ||||
|  | ||||
| # Node.js | ||||
| node_modules | ||||
| report.*.json | ||||
|  | ||||
| # Cypress | ||||
| cypress/screenshots | ||||
| cypress/videos | ||||
|  | ||||
| # config | ||||
| /.config/* | ||||
| !/.config/example.yml | ||||
| !/.config/docker_example.env | ||||
|  | ||||
| # misskey | ||||
| !/.config/mongo_initdb_example.js | ||||
| /.vscode | ||||
| /node_modules | ||||
| /build | ||||
| /built | ||||
| built | ||||
| /data | ||||
| /.cache-loader | ||||
| /db | ||||
| /elasticsearch | ||||
| npm-debug.log | ||||
| *.pem | ||||
| run.bat | ||||
| api-docs.json | ||||
| *.log | ||||
| /redis | ||||
| /mongo | ||||
| /elasticsearch | ||||
| *.code-workspace | ||||
| yarn.lock | ||||
| .DS_Store | ||||
| /files | ||||
| ormconfig.json | ||||
|  | ||||
| # blender backups | ||||
| *.blend1 | ||||
| *.blend2 | ||||
| *.blend3 | ||||
| *.blend4 | ||||
| *.blend5 | ||||
|   | ||||
							
								
								
									
										3
									
								
								.gitmodules
									
									
									
									
										vendored
									
									
								
							
							
						
						| @@ -1,3 +0,0 @@ | ||||
| [submodule "misskey-assets"] | ||||
| 	path = misskey-assets | ||||
| 	url = https://github.com/misskey-dev/assets.git | ||||
| @@ -1 +1 @@ | ||||
| v16.15.0 | ||||
| v11.7.0 | ||||
|   | ||||
| @@ -1,6 +0,0 @@ | ||||
| build: | ||||
|   misskey: | ||||
|     args: | ||||
|       - NODE_ENV=development | ||||
| deploy: | ||||
|   - helm upgrade --install misskey chart --set image=${OKTETO_BUILD_MISSKEY_IMAGE} --set url="https://misskey-$(kubectl config view --minify -o jsonpath='{..namespace}').cloud.okteto.net" --set environment=development | ||||
							
								
								
									
										9
									
								
								.vscode/extensions.json
									
									
									
									
										vendored
									
									
								
							
							
						
						| @@ -1,9 +1,12 @@ | ||||
| { | ||||
| 	"recommendations": [ | ||||
| 		"ducksoupdev.vue2", | ||||
| 		"editorconfig.editorconfig", | ||||
| 		"eg2.tslint", | ||||
| 		"eg2.vscode-npm-script", | ||||
| 		"dbaeumer.vscode-eslint", | ||||
| 		"Vue.volar", | ||||
| 		"Vue.vscode-typescript-vue-plugin" | ||||
| 		"hollowtree.vue-snippets", | ||||
| 		"ms-vscode.typescript-javascript-grammar", | ||||
| 		"octref.vetur", | ||||
| 		"sysoev.language-stylus" | ||||
| 	] | ||||
| } | ||||
|   | ||||
							
								
								
									
										1536
									
								
								CHANGELOG.md
									
									
									
									
									
								
							
							
						
						
							
								
								
									
										307
									
								
								CONTRIBUTING.md
									
									
									
									
									
								
							
							
						
						| @@ -1,278 +1,77 @@ | ||||
| # Contribution guide | ||||
| We're glad you're interested in contributing Misskey! In this document you will find the information you need to contribute to the project. | ||||
|  | ||||
| > **Note** | ||||
| > This project uses Japanese as its major language, **but you do not need to translate and write the Issues/PRs in Japanese.** | ||||
| > Also, you might receive comments on your Issue/PR in Japanese, but you do not need to reply to them in Japanese as well.\ | ||||
| > The accuracy of machine translation into Japanese is not high, so it will be easier for us to understand if you write it in the original language. | ||||
| > It will also allow the reader to use the translation tool of their preference if necessary. | ||||
|  | ||||
| ## Roadmap | ||||
| See [ROADMAP.md](./ROADMAP.md) | ||||
| :v: Thanks for your contributions :v: | ||||
|  | ||||
| ## Issues | ||||
| Before creating an issue, please check the following: | ||||
| - To avoid duplication, please search for similar issues before creating a new issue. | ||||
| - Do not use Issues to ask questions or troubleshooting. | ||||
| 	- Issues should only be used to feature requests, suggestions, and bug tracking. | ||||
| 	- Please ask questions or troubleshooting in the [Misskey Forum](https://forum.misskey.io/) or [Discord](https://discord.gg/Wp8gVStHW3). | ||||
|  | ||||
| > **Warning** | ||||
| > Do not close issues that are about to be resolved. It should remain open until a commit that actually resolves it is merged. | ||||
|  | ||||
| ## Before implementation | ||||
| When you want to add a feature or fix a bug, **first have the design and policy reviewed in an Issue** (if it is not there, please make one). Without this step, there is a high possibility that the PR will not be merged even if it is implemented. | ||||
|  | ||||
| At this point, you also need to clarify the goals of the PR you will create, and make sure that the other members of the team are aware of them. | ||||
| PRs that do not have a clear set of do's and don'ts tend to be bloated and difficult to review. | ||||
|  | ||||
| Also, when you start implementation, assign yourself to the Issue (if you cannot do it yourself, ask another member to assign you). By expressing your intention to work the Issue, you can prevent conflicts in the work. | ||||
|  | ||||
| ## Well-known branches | ||||
| - **`master`** branch is tracking the latest release and used for production purposes. | ||||
| - **`develop`** branch is where we work for the next release. | ||||
| 	- When you create a PR, basically target it to this branch. | ||||
| - **`l10n_develop`** branch is reserved for localization management. | ||||
|  | ||||
| ## Creating a PR | ||||
| Thank you for your PR! Before creating a PR, please check the following: | ||||
| - If possible, prefix the title with a keyword that identifies the type of this PR, as shown below. | ||||
|   - `fix` / `refactor` / `feat` / `enhance` / `perf` / `chore` etc | ||||
|   - Also, make sure that the granularity of this PR is appropriate. Please do not include more than one type of change or interest in a single PR. | ||||
| - If there is an Issue which will be resolved by this PR, please include a reference to the Issue in the text. | ||||
| - Please add the summary of the changes to [`CHANGELOG.md`](/CHANGELOG.md). However, this is not necessary for changes that do not affect the users, such as refactoring. | ||||
| - Check if there are any documents that need to be created or updated due to this change. | ||||
| - If you have added a feature or fixed a bug, please add a test case if possible. | ||||
| - Please make sure that tests and Lint are passed in advance. | ||||
|   - You can run it with `npm run test` and `npm run lint`. [See more info](#testing) | ||||
| - If this PR includes UI changes, please attach a screenshot in the text. | ||||
|  | ||||
| Thanks for your cooperation 🤗 | ||||
|  | ||||
| ## Reviewers guide | ||||
| Be willing to comment on the good points and not just the things you want fixed 💯 | ||||
|  | ||||
| ### Review perspective | ||||
| - Scope | ||||
|   - Are the goals of the PR clear? | ||||
|   - Is the granularity of the PR appropriate? | ||||
| - Security | ||||
| 	- Does merging this PR create a vulnerability? | ||||
| - Performance | ||||
| 	- Will merging this PR cause unexpected performance degradation? | ||||
| 	- Is there a more efficient way? | ||||
| - Testing | ||||
| 	- Does the test ensure the expected behavior? | ||||
| 	- Are there any omissions or gaps? | ||||
| 	- Does it check for anomalies? | ||||
|  | ||||
| ## Deploy | ||||
| The `/deploy` command by issue comment can be used to deploy the contents of a PR to the preview environment. | ||||
| ``` | ||||
| /deploy sha=<commit hash> | ||||
| ``` | ||||
| An actual domain will be assigned so you can test the federation. | ||||
|  | ||||
| ## Merge | ||||
|  | ||||
| ## Release | ||||
| ### Release Instructions | ||||
| 1. Commit version changes in the `develop` branch ([package.json](https://github.com/misskey-dev/misskey/blob/develop/package.json)) | ||||
| 2. Create a release PR. | ||||
| 	- Into `master` from `develop` branch. | ||||
| 	- The title must be in the format `Release: x.y.z`. | ||||
| 		- `x.y.z` is the new version you are trying to release. | ||||
| 3. Deploy and perform a simple QA check. Also verify that the tests passed. | ||||
| 4. Merge it. | ||||
| 5. Create a [release of GitHub](https://github.com/misskey-dev/misskey/releases) | ||||
| 	- The target branch must be `master` | ||||
| 	- The tag name must be the version | ||||
| Feature suggestions and bug reports are filed in https://github.com/syuilo/misskey/issues . | ||||
| Before creating a new issue, please search existing issues to avoid duplication. | ||||
| If you find the existing issue, please add your reaction or comment to the issue. | ||||
|  | ||||
| ## Localization (l10n) | ||||
| Misskey uses [Crowdin](https://crowdin.com/project/misskey) for localization management. | ||||
| You can improve our translations with your Crowdin account. | ||||
| Your changes in Crowdin are automatically submitted as a PR (with the title "New Crowdin translations") to the repository. | ||||
| The owner [@syuilo](https://github.com/syuilo) merges the PR into the develop branch before the next release. | ||||
|  | ||||
| If your language is not listed in Crowdin, please open an issue. | ||||
| Please use [Crowdin](https://crowdin.com/project/misskey) for localization. | ||||
|  | ||||
|  | ||||
|  | ||||
| ## Development | ||||
| During development, it is useful to use the `npm run dev` command. | ||||
| This command monitors the server-side and client-side source files and automatically builds them if they are modified. | ||||
| In addition, it will also automatically start the Misskey server process. | ||||
| ## Internationalization (i18n) | ||||
| Misskey uses [vue-i18n](https://github.com/kazupon/vue-i18n). | ||||
|  | ||||
| ## Testing | ||||
| - Test codes are located in [`/test`](/test). | ||||
| ## Documentation | ||||
| * Documents for contributors are located in `/docs`. | ||||
| * Documents for instance admins are located in `/docs`. | ||||
| * Documents for end users are located in `src/docs`. | ||||
|  | ||||
| ### Run test | ||||
| Create a config file. | ||||
| ``` | ||||
| cp test/test.yml .config/ | ||||
| ``` | ||||
| Prepare DB/Redis for testing. | ||||
| ``` | ||||
| docker-compose -f test/docker-compose.yml up | ||||
| ``` | ||||
| Alternatively, prepare an empty (data can be erased) DB and edit `.config/test.yml`.  | ||||
|  | ||||
| Run all test. | ||||
| ``` | ||||
| npm run test | ||||
| ``` | ||||
|  | ||||
| #### Run specify test | ||||
| ``` | ||||
| npx cross-env TS_NODE_FILES=true TS_NODE_TRANSPILE_ONLY=true TS_NODE_PROJECT="./test/tsconfig.json" npx mocha test/foo.ts --require ts-node/register | ||||
| ``` | ||||
|  | ||||
| ### e2e tests | ||||
| TODO | ||||
| ## Test | ||||
| * Test codes are located in `/test`. | ||||
|  | ||||
| ## Continuous integration | ||||
| Misskey uses GitHub Actions for executing automated tests. | ||||
| Configuration files are located in [`/.github/workflows`](/.github/workflows). | ||||
| Misskey uses CircleCI for automated test. | ||||
| Configuration files are located in `/.circleci`. | ||||
|  | ||||
| ## Vue | ||||
| Misskey uses Vue(v3) as its front-end framework. | ||||
| - Use TypeScript. | ||||
| - **When creating a new component, please use the Composition API (with [setup sugar](https://v3.vuejs.org/api/sfc-script-setup.html) and [ref sugar](https://github.com/vuejs/rfcs/discussions/369)) instead of the Options API.** | ||||
| 	- Some of the existing components are implemented in the Options API, but it is an old implementation. Refactors that migrate those components to the Composition API are also welcome. | ||||
| ## Glossary | ||||
| ### AP | ||||
| Stands for _**A**ctivity**P**ub_. | ||||
|  | ||||
| ## nirax | ||||
| niraxは、Misskeyで使用しているオリジナルのフロントエンドルーティングシステムです。 | ||||
| **vue-routerから影響を多大に受けているので、まずはvue-routerについて学ぶことをお勧めします。** | ||||
| ### MFM | ||||
| Stands for _**M**isskey **F**lavored **M**arkdown_. | ||||
|  | ||||
| ### ルート定義 | ||||
| ルート定義は、以下の形式のオブジェクトの配列です。 | ||||
| ### Mk | ||||
| Stands for _**M**iss**k**ey_. | ||||
|  | ||||
| ### SW | ||||
| Stands for _**S**ervice**W**orker_. | ||||
|  | ||||
| ### Nyaize | ||||
| Convert な(na) to にゃ(nya) | ||||
|  | ||||
| #### Denyaize | ||||
| Revert Nyaize | ||||
|  | ||||
| ## Code style | ||||
| ### Use semicolon | ||||
| To avoid ASI Hazard | ||||
|  | ||||
| ### Don't use `export default` | ||||
| Bad: | ||||
| ``` ts | ||||
| { | ||||
| 	name?: string; | ||||
| 	path: string; | ||||
| 	component: Component; | ||||
| 	query?: Record<string, string>; | ||||
| 	loginRequired?: boolean; | ||||
| 	hash?: string; | ||||
| 	globalCacheKey?: string; | ||||
| 	children?: RouteDef[]; | ||||
| } | ||||
| export default function(foo: string): string { | ||||
| ``` | ||||
|  | ||||
| > **Warning** | ||||
| > 現状、ルートは定義された順に評価されます。 | ||||
| > たとえば、`/foo/:id`ルート定義の次に`/foo/bar`ルート定義がされていた場合、後者がマッチすることはありません。 | ||||
|  | ||||
| ### 複数のルーター | ||||
| vue-routerとの最大の違いは、niraxは複数のルーターが存在することを許可している点です。 | ||||
| これにより、アプリ内ウィンドウでブラウザとは個別にルーティングすることなどが可能になります。 | ||||
|  | ||||
| ## Notes | ||||
| ### How to resolve conflictions occurred at yarn.lock? | ||||
|  | ||||
| Just execute `yarn` to fix it. | ||||
|  | ||||
| ### INSERTするときにはsaveではなくinsertを使用する | ||||
| #6441 | ||||
|  | ||||
| ### placeholder | ||||
| SQLをクエリビルダで組み立てる際、使用するプレースホルダは重複してはならない | ||||
| 例えば | ||||
| Good: | ||||
| ``` ts | ||||
| query.andWhere(new Brackets(qb => { | ||||
| 	for (const type of ps.fileType) { | ||||
| 		qb.orWhere(`:type = ANY(note.attachedFileTypes)`, { type: type }); | ||||
| 	} | ||||
| })); | ||||
| ``` | ||||
| と書くと、ループ中で`type`というプレースホルダが複数回使われてしまいおかしくなる | ||||
| だから次のようにする必要がある | ||||
| ```ts | ||||
| query.andWhere(new Brackets(qb => { | ||||
| 	for (const type of ps.fileType) { | ||||
| 		const i = ps.fileType.indexOf(type); | ||||
| 		qb.orWhere(`:type${i} = ANY(note.attachedFileTypes)`, { [`type${i}`]: type }); | ||||
| 	} | ||||
| })); | ||||
| export function something(foo: string): string { | ||||
| ``` | ||||
|  | ||||
| ### Not `null` in TypeORM | ||||
| ```ts | ||||
| const foo = await Foos.findOne({ | ||||
| 	bar: Not(null) | ||||
| }); | ||||
| ## Directory structure | ||||
| ``` | ||||
| のようなクエリ(`bar`が`null`ではない)は期待通りに動作しない。 | ||||
| 次のようにします: | ||||
| ```ts | ||||
| const foo = await Foos.findOne({ | ||||
| 	bar: Not(IsNull()) | ||||
| }); | ||||
| src ... Source code | ||||
| 	@types ... Type definitions | ||||
| 	prelude ... Independence utils for coding JavaScript without side effects | ||||
| 	misc ... Independence utils for Misskey without side effects | ||||
| 	service ... Common functions with side effects | ||||
| 	queue ... Job queues and Jobs | ||||
| 	server ... Web Server | ||||
| 	client ... Client | ||||
| 	mfm ... MFM | ||||
|  | ||||
| test ... Test code | ||||
|  | ||||
| ``` | ||||
|  | ||||
| ### `null` in SQL | ||||
| SQLを発行する際、パラメータが`null`になる可能性のある場合はSQL文を出し分けなければならない | ||||
| 例えば | ||||
| ``` ts | ||||
| query.where('file.folderId = :folderId', { folderId: ps.folderId }); | ||||
| ``` | ||||
| という処理で、`ps.folderId`が`null`だと結果的に`file.folderId = null`のようなクエリが発行されてしまい、これは正しいSQLではないので期待した結果が得られない | ||||
| だから次のようにする必要がある | ||||
| ``` ts | ||||
| if (ps.folderId) { | ||||
| 	query.where('file.folderId = :folderId', { folderId: ps.folderId }); | ||||
| } else { | ||||
| 	query.where('file.folderId IS NULL'); | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ### `[]` in SQL | ||||
| SQLを発行する際、`IN`のパラメータが`[]`(空の配列)になる可能性のある場合はSQL文を出し分けなければならない | ||||
| 例えば | ||||
| ``` ts | ||||
| const users = await Users.find({ | ||||
| 	id: In(userIds) | ||||
| }); | ||||
| ``` | ||||
| という処理で、`userIds`が`[]`だと結果的に`user.id IN ()`のようなクエリが発行されてしまい、これは正しいSQLではないので期待した結果が得られない | ||||
| だから次のようにする必要がある | ||||
| ``` ts | ||||
| const users = userIds.length > 0 ? await Users.find({ | ||||
| 	id: In(userIds) | ||||
| }) : []; | ||||
| ``` | ||||
|  | ||||
| ### 配列のインデックス in SQL | ||||
| SQLでは配列のインデックスは**1始まり**。 | ||||
| `[a, b, c]`の `a`にアクセスしたいなら`[0]`ではなく`[1]`と書く | ||||
|  | ||||
| ### null IN | ||||
| nullが含まれる可能性のあるカラムにINするときは、そのままだとおかしくなるのでORなどでnullのハンドリングをしよう。 | ||||
|  | ||||
| ### `undefined`にご用心 | ||||
| MongoDBの時とは違い、findOneでレコードを取得する時に対象レコードが存在しない場合 **`undefined`** が返ってくるので注意。 | ||||
| MongoDBは`null`で返してきてたので、その感覚で`if (x === null)`とか書くとバグる。代わりに`if (x == null)`と書いてください | ||||
|  | ||||
| ### Migration作成方法 | ||||
| packages/backendで: | ||||
| ```sh | ||||
| npx typeorm migration:generate -d ormconfig.js -o <migration name> | ||||
| ``` | ||||
|  | ||||
| - 生成後、ファイルをmigration下に移してください | ||||
| - 作成されたスクリプトは不必要な変更を含むため除去してください | ||||
|  | ||||
| ### コネクションには`markRaw`せよ | ||||
| **Vueのコンポーネントのdataオプションとして**misskey.jsのコネクションを設定するとき、必ず`markRaw`でラップしてください。インスタンスが不必要にリアクティブ化されることで、misskey.js内の処理で不具合が発生するとともに、パフォーマンス上の問題にも繋がる。なお、Composition APIを使う場合はこの限りではない(リアクティブ化はマニュアルなため)。 | ||||
|  | ||||
| ### JSONのimportに気を付けよう | ||||
| TypeScriptでjsonをimportすると、tscでコンパイルするときにそのjsonファイルも一緒にdistディレクトリに吐き出されてしまう。この挙動により、意図せずファイルの書き換えが発生することがあるので、jsonをimportするときは書き換えられても良いものかどうか確認すること。書き換えされて欲しくない場合は、importで読み込むのではなく、`fs.readFileSync`などの関数を使って読み込むようにすればよい。 | ||||
|  | ||||
| ### コンポーネントのスタイル定義でmarginを持たせない | ||||
| コンポーネント自身がmarginを設定するのは問題の元となることはよく知られている | ||||
| marginはそのコンポーネントを使う側が設定する | ||||
|  | ||||
| ## その他 | ||||
| ### HTMLのクラス名で follow という単語は使わない | ||||
| 広告ブロッカーで誤ってブロックされる | ||||
|   | ||||
							
								
								
									
										19
									
								
								COPYING
									
									
									
									
									
								
							
							
						
						| @@ -1,19 +0,0 @@ | ||||
| Unless otherwise stated this repository is | ||||
| Copyright © 2014-2022 syuilo and contributers | ||||
|  | ||||
| And is distributed under The GNU Affero General Public License Version 3, you should have received a copy of the license file as LICENSE. | ||||
|  | ||||
|  | ||||
| Misskey includes several third-party Open-Source softwares. | ||||
|  | ||||
| Emoji keywords for Unicode 11 and below by Mu-An Chiou | ||||
| License: MIT | ||||
| https://github.com/muan/emojilib/blob/master/LICENSE | ||||
|  | ||||
| RsaSignature2017 implementation by Transmute Industries Inc | ||||
| License: MIT | ||||
| https://github.com/transmute-industries/RsaSignature2017/blob/master/LICENSE | ||||
|  | ||||
| Machine learning model for sensitive images by Infinite Red, Inc. | ||||
| License: MIT | ||||
| https://github.com/infinitered/nsfwjs/blob/master/LICENSE | ||||
							
								
								
									
										46
									
								
								Dockerfile
									
									
									
									
									
								
							
							
						
						| @@ -1,32 +1,42 @@ | ||||
| FROM node:16.15.1-bullseye AS builder | ||||
| FROM node:11-alpine AS base | ||||
|  | ||||
| ARG NODE_ENV=production | ||||
| ENV NODE_ENV=production | ||||
|  | ||||
| RUN npm i -g npm@latest | ||||
|  | ||||
| WORKDIR /misskey | ||||
|  | ||||
| FROM base AS builder | ||||
|  | ||||
| RUN apk add --no-cache \ | ||||
|     autoconf \ | ||||
|     automake \ | ||||
|     file \ | ||||
|     g++ \ | ||||
|     gcc \ | ||||
|     libc-dev \ | ||||
|     libtool \ | ||||
|     make \ | ||||
|     nasm \ | ||||
|     pkgconfig \ | ||||
|     python \ | ||||
|     zlib-dev | ||||
| RUN npm i -g yarn | ||||
|  | ||||
| COPY . ./ | ||||
|  | ||||
| RUN apt-get update | ||||
| RUN apt-get install -y build-essential | ||||
| RUN git submodule update --init | ||||
| RUN yarn install | ||||
| RUN yarn build | ||||
| RUN rm -rf .git | ||||
|  | ||||
| FROM node:16.15.1-bullseye-slim AS runner | ||||
| FROM base AS runner | ||||
|  | ||||
| WORKDIR /misskey | ||||
|  | ||||
| RUN apt-get update | ||||
| RUN apt-get install -y ffmpeg tini | ||||
| RUN apk add --no-cache \ | ||||
|     ffmpeg \ | ||||
|     tini | ||||
| RUN npm i -g web-push | ||||
| ENTRYPOINT ["/sbin/tini", "--"] | ||||
|  | ||||
| COPY --from=builder /misskey/node_modules ./node_modules | ||||
| 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 . ./ | ||||
|  | ||||
| ENV NODE_ENV=production | ||||
| ENTRYPOINT ["/usr/bin/tini", "--"] | ||||
| CMD ["npm", "run", "migrateandstart"] | ||||
| CMD ["npm", "start"] | ||||
|   | ||||
							
								
								
									
										234
									
								
								README.md
									
									
									
									
									
								
							
							
						
						| @@ -1,57 +1,205 @@ | ||||
| <div align="center"> | ||||
| <a href="https://misskey-hub.net"> | ||||
| 	<img src="./assets/title_float.svg" alt="Misskey logo" style="border-radius:50%" width="400"/> | ||||
| </a> | ||||
| 	 | ||||
| **🌎 **[Misskey](https://misskey-hub.net/)** is an open source, decentralized social media platform that's free forever! 🚀** | ||||
| 	 | ||||
| <a href="https://ai.misskey.xyz/"><img src="https://github.com/syuilo/misskey/blob/develop/assets/ai-orig.png?raw=true" align="right" height="320px"/></a> | ||||
|  | ||||
| [](https://misskey.xyz/) | ||||
| ================================================================ | ||||
|  | ||||
| [](https://circleci.com/gh/syuilo/misskey) | ||||
| [](https://david-dm.org/syuilo/misskey) | ||||
| [](http://makeapullrequest.com) | ||||
|  | ||||
| **A forever evolving, sophisticated microblogging platform.** | ||||
|  | ||||
| <p align="justify"> | ||||
| <a href="https://misskey.xyz">Misskey</a> is a decentralized microblogging platform born on Earth. | ||||
| Since it exists within the Fediverse (a universe where various social media platforms are organized), | ||||
| it is mutually linked with other social media platforms. | ||||
| Why don't you take a short break from the hustle and bustle of the city, and dive into a new Internet? <a href="https://joinmisskey.github.io/">Find an instance!</a> | ||||
| </p> | ||||
|  | ||||
| <a href="https://www.patreon.com/syuilo"><img src="https://c5.patreon.com/external/logo/become_a_patron_button@2x.png" alt="Become a Patron!" width="160" /></a> | ||||
|  | ||||
|  | ||||
|  | ||||
| :sparkles: Features | ||||
| ---------------------------------------------------------------- | ||||
|  | ||||
| <img src="/assets/about/post.png" align="left" height="200px"/> | ||||
|  | ||||
| <h3 align="left">Posting</h3> | ||||
| <p align="justify"> | ||||
| Post your ideas, discussion topics, fun moments, or anything else you want to share! Misskey supports text, emoji, pictures, videos, and polls! | ||||
| </p> | ||||
|  | ||||
| --- | ||||
|  | ||||
| <a href="https://misskey-hub.net/instances.html"> | ||||
| 		<img src="https://custom-icon-badges.herokuapp.com/badge/find_an-instance-acea31?logoColor=acea31&style=for-the-badge&logo=misskey&labelColor=363B40" alt="find an instance"/></a> | ||||
| <img src="/assets/about/reaction.png" align="right" height="200px"/> | ||||
|  | ||||
| <a href="https://misskey-hub.net/docs/install.html"> | ||||
| 		<img src="https://custom-icon-badges.herokuapp.com/badge/create_an-instance-FBD53C?logoColor=FBD53C&style=for-the-badge&logo=server&labelColor=363B40" alt="create an instance"/></a> | ||||
| <h3 align="right">Reactions</h3> | ||||
| <p align="justify"> | ||||
| Reactions are the simplest way to respond to others' posts. Simply pick a reaction emote from the list! Reactions on Misskey are much more expressive than other social media services which only allow “liking”. | ||||
| </p> | ||||
|  | ||||
| <a href="./CONTRIBUTING.md"> | ||||
| 		<img src="https://custom-icon-badges.herokuapp.com/badge/become_a-contributor-A371F7?logoColor=A371F7&style=for-the-badge&logo=git-merge&labelColor=363B40" alt="become a contributor"/></a> | ||||
|  | ||||
| <a href="https://discord.gg/Wp8gVStHW3"> | ||||
| 		<img src="https://custom-icon-badges.herokuapp.com/badge/join_the-community-5865F2?logoColor=5865F2&style=for-the-badge&logo=discord&labelColor=363B40" alt="join the community"/></a> | ||||
|  | ||||
| <a href="https://www.patreon.com/syuilo"> | ||||
| 		<img src="https://custom-icon-badges.herokuapp.com/badge/become_a-patron-F96854?logoColor=F96854&style=for-the-badge&logo=patreon&labelColor=363B40" alt="become a patron"/></a> | ||||
| 	 | ||||
| --- | ||||
|  | ||||
| </div> | ||||
| <img src="/assets/about/ui.png" align="left" height="200px"/> | ||||
|  | ||||
| <div> | ||||
| <h3 align="left">Interface</h3> | ||||
| <p align="justify"> | ||||
| Customize the UI to your own tastes! No UI will work for everyone, so Misskey is completely customizable. Make Misskey *yours* by editing the style, adjusting timeline layouts, and placing widgets. | ||||
| </p> | ||||
|  | ||||
| <a href="https://xn--931a.moe/"><img src="https://github.com/misskey-dev/misskey/blob/develop/assets/ai.png?raw=true" align="right" height="320px"/></a> | ||||
| --- | ||||
|  | ||||
| ## ✨ Features | ||||
| - **ActivityPub support**\ | ||||
| Not on Misskey? No problem! Not only can Misskey instances talk to each other, but you can make friends with people on other networks like Mastodon and Pixelfed! | ||||
| - **Reactions**\ | ||||
| You can add emoji reactions to any post! No longer are you bound by a like button, show everyone exactly how you feel with the tap of a button. | ||||
| - **Drive**\ | ||||
| With Misskey's built in drive, you get cloud storage right in your social media, where you can upload any files, make folders, and find media from posts you've made! | ||||
| - **Rich Web UI**\ | ||||
| 	Misskey has a rich and easy to use Web UI! | ||||
| 	It is highly customizable, from changing the layout and adding widgets to making custom themes. | ||||
| 	Furthermore, plugins can be created using AiScript, an original programming language. | ||||
| - And much more... | ||||
| <img src="/assets/about/drive.png" align="right" width="300px"/> | ||||
|  | ||||
| </div> | ||||
| <h3 align="right">Misskey Drive</h3> | ||||
| <p align="justify"> | ||||
| Organize and store your files! Want to post a picture you have already uploaded? Wish you could organize your files into folders? Misskey Drive is a solution! | ||||
| </p> | ||||
|  | ||||
| <div style="clear: both;"></div> | ||||
| --- | ||||
|  | ||||
| ## Documentation | ||||
| ...and more! Experience Misskey with your own eyes at [misskey.xyz](https://misskey.xyz) or join one of the [other instances](https://joinmisskey.github.io/) that are available. | ||||
|  | ||||
| Misskey Documentation can be found at [Misskey Hub](https://misskey-hub.net/), some of the links and graphics above also lead to specific portions of it. | ||||
| Screen shots | ||||
| ---------------------------------------------------------------- | ||||
| ### Profile page | ||||
| <img src="/assets/ss/user.jpg" width="500px"/> | ||||
|  | ||||
| ## Sponsors | ||||
| <div align="center"> | ||||
| 	<a class="rss3" title="RSS3" href="https://rss3.io/" target="_blank"><img src="https://rss3.mypinata.cloud/ipfs/QmUG6H3Z7D5P511shn7sB4CPmpjH5uZWu4m5mWX7U3Gqbu" alt="RSS3" height="60"></a> | ||||
| </div> | ||||
| ### Explore users | ||||
| <img src="/assets/ss/explore.jpg" width="500px"/> | ||||
|  | ||||
| :new: What's new | ||||
| ---------------------------------------------------------------- | ||||
| Please see the [Release notes](./CHANGELOG.md). | ||||
|  | ||||
| :package: Create your own instance | ||||
| ---------------------------------------------------------------- | ||||
| Please see the [Setup and Installation Guide](./docs/setup.en.md). | ||||
|  | ||||
| :wrench: Contribution | ||||
| ---------------------------------------------------------------- | ||||
| Please see the [Contribution Guide](./CONTRIBUTING.md). | ||||
|  | ||||
| ### Collaborators | ||||
| <table> | ||||
| 	<tr> | ||||
| 		<td><img src="https://avatars3.githubusercontent.com/u/4439005?s=460&v=4" alt="syuilo" width="100"></td> | ||||
| 		<td><img src="https://avatars0.githubusercontent.com/u/10798641?s=460&v=4" alt="AyaMorisawa" width="100"></td> | ||||
| 		<td><img src="https://avatars1.githubusercontent.com/u/30769358?s=460&v=4" alt="mei23" width="100"></td> | ||||
| 		<td><img src="https://avatars2.githubusercontent.com/u/20679825?s=460&v=4" alt="acid-chicken" width="100"></td> | ||||
| 		<td><img src="https://avatars2.githubusercontent.com/u/6533808?s=460&v=4" alt="rinsuki" width="100"></td> | ||||
| 	</tr> | ||||
| 	<tr> | ||||
| 		<td align="center"><a href="https://github.com/syuilo">@syuilo</a></td> | ||||
| 		<td align="center"><a href="https://github.com/AyaMorisawa">@AyaMorisawa</a></td> | ||||
| 		<td align="center"><a href="https://github.com/mei23">@mei23</a></td> | ||||
| 		<td align="center"><a href="https://github.com/acid-chicken">@acid-chicken</a></td> | ||||
| 		<td align="center"><a href="https://github.com/rinsuki">@rinsuki</a></td> | ||||
| 	</tr> | ||||
| </table> | ||||
|  | ||||
| :heart: Backers | ||||
| ---------------------------------------------------------------- | ||||
| <!-- PATREON_START --> | ||||
| <table><tr> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/5888816/36da0f7c15954df0ab13f9abdf227f66/1.jpeg?token-time=2145916800&token-hash=at8QpJXJ8C0zINY_NmoMKv-MhXVoUK-YzTgaJPJzJYU%3D" alt="Hiroshi Seki" width="100"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/12190916/fb7fa7983c14425f890369535b1506a4/3.png?token-time=2145916800&token-hash=oH_i7gJjNT7Ot6j9JiVwy7ZJIBqACVnzLqlz4YrDAZA%3D" alt="weepjp" width="100"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/19045173/cb91c0f345c24d4ebfd05f19906d5e26/1.png?token-time=2145916800&token-hash=o_zKBytJs_AxHwSYw_5R8eD0eSJe3RoTR3kR3Q0syN0%3D" alt="kiritan" width="100"></td> | ||||
| <td><img src="https://c8.patreon.com/2/200/776209" alt="Denshi" width="100"></td> | ||||
| <td><img src="https://c8.patreon.com/2/200/557245" alt="mkatze" width="100"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/13099460/43cecdbaa63a40d79bf50a96b9910b9d/1.jpe?token-time=2145916800&token-hash=bqwLTk0Wo0hUJJ8J5y7ii05bLzz-_CDA7Bo0Mp4RFU0%3D" alt="ne_moni" width="100"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/12913507/f7181eacafe8469a93033d85f5969c29/4.jpe?token-time=2145916800&token-hash=zEyJqVM7u9d8Ri-65fJYSJcWF1jBH1nJ5a3taRzrTmw%3D" alt="Melilot" width="100"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/5670915/ee175f0bfb6347ffa4ea101a8c097bff/1.jpg?token-time=2145916800&token-hash=mPLM9CA-riFHx-myr3bLZJuH2xBRHA9se5VbHhLIOuA%3D" alt="osapon" width="100"></td> | ||||
| </tr><tr> | ||||
| <td><a href="https://www.patreon.com/rane_hs">Hiroshi Seki</a></td> | ||||
| <td><a href="https://www.patreon.com/weepjp">weepjp</a></td> | ||||
| <td><a href="https://www.patreon.com/user?u=19045173">kiritan</a></td> | ||||
| <td><a href="https://www.patreon.com/user?u=776209">Denshi</a></td> | ||||
| <td><a href="https://www.patreon.com/user?u=557245">mkatze</a></td> | ||||
| <td><a href="https://www.patreon.com/user?u=13099460">ne_moni</a></td> | ||||
| <td><a href="https://www.patreon.com/user?u=12913507">Melilot</a></td> | ||||
| <td><a href="https://www.patreon.com/osapon">osapon</a></td> | ||||
| </tr></table> | ||||
| <table><tr> | ||||
| <td><img src="https://c8.patreon.com/2/200/16869916" alt="見当かなみ" width="100"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/18899730/6a22797f68254034a854d69ea2445fc8/1.png?token-time=2145916800&token-hash=b_uj57yxo5VzkSOUS7oXE_762dyOTB_oxzbO6lFNG3k%3D" alt="YuzuRyo61" width="100"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/12021162/963128bb8d14476dbd8407943db8f31a/1.png?token-time=2145916800&token-hash=FMV7cPKBD1TU2WTbl1jg6AcdKSvTb2BSFcDhgc-EO8w%3D" alt="gutfuckllc" width="100"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/11357794/923ce94cd8c44ba788ee931907881839/1.png?token-time=2145916800&token-hash=9nEQje_eMvUjq9a7L3uBqW-MQbS-rRMaMgd7UYVoFNM%3D" alt="mydarkstar" width="100"></td> | ||||
| <td><img src="https://c8.patreon.com/2/200/12718187" alt="Peter G." width="100"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/13039004/509d0c412eb14ae08d6a812a3054f7d6/1.jpe?token-time=2145916800&token-hash=UQRWf01TwHDV4Cls1K0YAOAjM29ssif7hLVq0ESQ0hs%3D" alt="nemu" width="100"></td> | ||||
| <td><img src="https://c8.patreon.com/2/200/17866454" alt="sikyosyounin" width="100"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/5881381/6235ca5d3fb04c8e95ef5b4ff2abcc18/3.png?token-time=2145916800&token-hash=KjfQL8nf3AIf6WqzLshBYAyX44piAqOAZiYXgZS_H6A%3D" alt="YUKIMOCHI" width="100"></td> | ||||
| <td><img src="https://c8.patreon.com/2/200/17463605" alt="Sampot" width="100"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/19356899/496b4681d33b4520bd7688e0fd19c04d/2.jpeg?token-time=2145916800&token-hash=_sTj3dUBOhn9qwiJ7F19Qd-yWWfUqJC_0jG1h0agEqQ%3D" alt="sheeta.s" width="100"></td> | ||||
| </tr><tr> | ||||
| <td><a href="https://www.patreon.com/user?u=16869916">見当かなみ</a></td> | ||||
| <td><a href="https://www.patreon.com/Yuzulia">YuzuRyo61</a></td> | ||||
| <td><a href="https://www.patreon.com/gutfuckllc">gutfuckllc</a></td> | ||||
| <td><a href="https://www.patreon.com/mydarkstar">mydarkstar</a></td> | ||||
| <td><a href="https://www.patreon.com/user?u=12718187">Peter G.</a></td> | ||||
| <td><a href="https://www.patreon.com/user?u=13039004">nemu</a></td> | ||||
| <td><a href="https://www.patreon.com/user?u=17866454">sikyosyounin</a></td> | ||||
| <td><a href="https://www.patreon.com/yukimochi">YUKIMOCHI</a></td> | ||||
| <td><a href="https://www.patreon.com/user?u=17463605">Sampot</a></td> | ||||
| <td><a href="https://www.patreon.com/user?u=19356899">sheeta.s</a></td> | ||||
| </tr></table> | ||||
| <table><tr> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/13737140/1adf7835017d479280d90fe8d30aade2/1.png?token-time=2145916800&token-hash=0pdle8h5pDZrww0BDOjdz6zO-HudeGTh36a3qi1biVU%3D" alt="Satsuki Yanagi" width="100"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/17880724/311738c8a48f4a6b9443c2445a75adde/1.jpe?token-time=2145916800&token-hash=CPxGQhKIlEaa6WUcgbyHixyKEhakiw9RFdOhsIJBQ_o%3D" alt="takimura" width="100"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/17195955/be45e5e14c3e48b2bee0456c84e19df4/4.jpe?token-time=2145916800&token-hash=UslrPVM-8TXOe8AapuNiaFYjcIJgPNcU-fKpGbfGJNI%3D" alt="Damillora" width="100"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/16900731/83884b38afc74d4cbe83c30a13b10edd/1.png?token-time=2145916800&token-hash=R5Tog8RWg0rguRoCIoir3lThokrdPvs8Utfikhc0nhY%3D" alt="Atsuko Tominaga" width="100"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/4389829/9f709180ac714651a70f74a82f3ffdb9/3.png?token-time=2145916800&token-hash=FTm3WVom4dJ9NwWMU4OpCL_8Yc13WiwEbKrDPyTZTPs%3D" alt="natalie" width="100"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/13034746/c711c7f58e204ecfbc2fd646bc8a4eee/1.jpe?token-time=2145916800&token-hash=EWxXhVbZYH7KB4IDT3joc8TbIg8zPO40x1r5IDn3R7c%3D" alt="Hiratake" width="100"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/5923936/2a743cbfbff946c2af3f09026047c0da/2.png?token-time=2145916800&token-hash=h6yphW1qnM0n_NOWaf8qtszMRLXEwIxfk5beu4RxdT0%3D" alt="noellabo" width="100"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/2384390/5681180e1efb46a8b28e0e8d4c8b9037/1.jpg?token-time=2145916800&token-hash=SJcMy-Q1BcS940-LFUVOMfR7-5SgrzsEQGhYb3yowFk%3D" alt="CG" width="100"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/18072312/98e894d960314fa7bc236a72a39488fe/1.jpe?token-time=2145916800&token-hash=qA8j97lIZNc-74AuZ0p4F3ms6sKPeKjtNt2vEuwpsyo%3D" alt="Hekovic" width="100"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/10789744/97175095d8f04c0f86225ff47cb98d40/1.jpeg?token-time=2145916800&token-hash=l4AoMR7Nj7K4yAHrkrk2hAoggPkbSPm12m1nmbe9Pb8%3D" alt="Naoki Hirayama" width="100"></td> | ||||
| </tr><tr> | ||||
| <td><a href="https://www.patreon.com/user?u=13737140">Satsuki Yanagi</a></td> | ||||
| <td><a href="https://www.patreon.com/takimura">takimura</a></td> | ||||
| <td><a href="https://www.patreon.com/damillora">Damillora</a></td> | ||||
| <td><a href="https://www.patreon.com/user?u=16900731">Atsuko Tominaga</a></td> | ||||
| <td><a href="https://www.patreon.com/user?u=4389829">natalie</a></td> | ||||
| <td><a href="https://www.patreon.com/hiratake">Hiratake</a></td> | ||||
| <td><a href="https://www.patreon.com/noellabo">noellabo</a></td> | ||||
| <td><a href="https://www.patreon.com/Corset">CG</a></td> | ||||
| <td><a href="https://www.patreon.com/hekovic">Hekovic</a></td> | ||||
| <td><a href="https://www.patreon.com/spinlock">Naoki Hirayama</a></td> | ||||
| </tr></table> | ||||
| <table><tr> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/4503830/ccf2cc867ea64de0b524bb2e24b9a1cb/1.jpeg?token-time=2145916800&token-hash=L55UhJ0rcuNAH3w_ryeeGN4hC6taoOixyAhraEi0bzw%3D" alt="dansup" width="100"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/619786/32cf01444db24e578cd1982c197f6fc6/1.jpeg?token-time=2145916800&token-hash=d8jBQLMOHD87KtXs5C9fk1o58DMF73pQ-dYH3uZJPBE%3D" alt="Gargron" width="100"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/5731881/4b6038e6cda34c04b83a5fcce3806a93/1.png?token-time=2145916800&token-hash=hBayGfOmQH3kRMdNnDe4oCZD_9fsJWSt29xXR3KRMVk%3D" alt="Nokotaro Takeda" width="100"></td> | ||||
| <td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/12531784/93a45137841849329ba692da92ac7c60/1.jpeg?token-time=2145916800&token-hash=vGe7wXGqmA8Q7m-kDNb6fyGdwk-Dxk4F-ut8ZZu51RM%3D" alt="Takashi Shibuya" width="100"></td> | ||||
| </tr><tr> | ||||
| <td><a href="https://www.patreon.com/dansup">dansup</a></td> | ||||
| <td><a href="https://www.patreon.com/mastodon">Gargron</a></td> | ||||
| <td><a href="https://www.patreon.com/takenoko">Nokotaro Takeda</a></td> | ||||
| <td><a href="https://www.patreon.com/user?u=12531784">Takashi Shibuya</a></td> | ||||
| </tr></table> | ||||
|  | ||||
| **Last updated:** Mon, 03 Jun 2019 17:28:09 UTC | ||||
| <!-- PATREON_END --> | ||||
|  | ||||
| :four_leaf_clover: Copyright | ||||
| ---------------------------------------------------------------- | ||||
| > Copyright (c) 2014-2019 syuilo | ||||
|  | ||||
| Misskey is open-source software licensed under the [GNU AGPLv3](LICENSE). | ||||
|  | ||||
| [![][agpl-3.0-badge]][AGPL-3.0] | ||||
|  | ||||
| [agpl-3.0]:           https://www.gnu.org/licenses/agpl-3.0.en.html | ||||
| [agpl-3.0-badge]:     https://img.shields.io/badge/license-AGPL--3.0-444444.svg?style=for-the-badge | ||||
|  | ||||
| [backer-url]: #backers | ||||
| [backer-badge]: https://opencollective.com/misskey/backers/badge.svg | ||||
| [backers-image]: https://opencollective.com/misskey/backers.svg | ||||
| [sponsor-url]: #sponsors | ||||
| [sponsor-badge]: https://opencollective.com/misskey/sponsors/badge.svg | ||||
| [sponsors-image]: https://opencollective.com/misskey/sponsors.svg | ||||
| [support-url]: https://opencollective.com/misskey#support | ||||
|  | ||||
| [syuilo-link]:      https://syuilo.com | ||||
| [syuilo-icon]:      https://avatars2.githubusercontent.com/u/4439005?v=3&s=70 | ||||
|   | ||||
							
								
								
									
										37
									
								
								ROADMAP.md
									
									
									
									
									
								
							
							
						
						| @@ -1,37 +0,0 @@ | ||||
| # Roadmap | ||||
| The order of individual tasks is a guide only and is subject to change depending on the situation. | ||||
| Also, the later tasks are more indefinite and are subject to change as development progresses. | ||||
|  | ||||
| ## (1) Improve maintainability \<current phase\> | ||||
| This is the phase we are at now. We need to make a high-maintenance environment that can withstand future development. | ||||
|  | ||||
| - Make the number of type errors zero (backend) | ||||
|   - Probably need to switch some libraries to others that make it difficult to reduce type errors | ||||
|     - e.g. koa to fastify https://github.com/misskey-dev/misskey/issues/7537 | ||||
| - Improve CI | ||||
|   - Fix tests | ||||
|     - mocha, jest, etc. do not support the combination of `TypeScript + ESM + Path alias`, and the tests currently do not work. | ||||
|   - Fix random test failures - https://github.com/misskey-dev/misskey/issues/7985 and https://github.com/misskey-dev/misskey/issues/7986 | ||||
|   - Add more tests | ||||
|     - May need to implement a mechanism that allows for DI | ||||
| - Improve documentation | ||||
|  | ||||
| ## (2) Improve functionality | ||||
| Once Phase 1 is complete and an environment conducive to the development of a stable system is in place, the implementation of new functions can begin gradually. | ||||
|  | ||||
| - Improve features for moderation | ||||
| - OAuth2 support https://github.com/misskey-dev/misskey/issues/8262 | ||||
| - GraphQL support? | ||||
|  | ||||
| ## (3) Improve scalability | ||||
| Once the development of the feature has settled down, this may be an opportunity to make larger modifications. | ||||
|  | ||||
| - Rewriting in Rust? | ||||
|  | ||||
| ## (4) Change the world | ||||
| It is time to promote Misskey and change the world. | ||||
|  | ||||
| - Become more major than services such as Twitter and become critical infrastructure for the world | ||||
| - MiOS will be developed and integrated into various systems - What is MiOS? | ||||
| - Letting Ai-chan interfere with the real world | ||||
| - Make Misskey a member of GAFA; Misskey's office must be a reinforced concrete brutalist building with a courtyard. | ||||
| @@ -1,9 +0,0 @@ | ||||
| # Reporting Security Issues | ||||
|  | ||||
| If you discover a security issue in Misskey, please report it by sending an | ||||
| email to [syuilotan@yahoo.co.jp](mailto:syuilotan@yahoo.co.jp). | ||||
|  | ||||
| This will allow us to assess the risk, and make a fix available before we add a | ||||
| bug report to the GitHub repository. | ||||
|  | ||||
| Thanks for helping make Misskey safe for everyone. | ||||
| Before Width: | Height: | Size: 5.4 KiB After Width: | Height: | Size: 5.4 KiB | 
							
								
								
									
										
											BIN
										
									
								
								assets/apple-touch-icon.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 2.5 KiB | 
							
								
								
									
										
											BIN
										
									
								
								assets/favicon.ico
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 6.8 KiB | 
							
								
								
									
										
											BIN
										
									
								
								assets/favicon/favicon.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 3.9 KiB | 
							
								
								
									
										53
									
								
								assets/favicon/favicon.svg
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,53 @@ | ||||
| <?xml version="1.0" encoding="UTF-8" standalone="no"?> | ||||
| <svg | ||||
|    xmlns:dc="http://purl.org/dc/elements/1.1/" | ||||
|    xmlns:cc="http://creativecommons.org/ns#" | ||||
|    xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" | ||||
|    xmlns:svg="http://www.w3.org/2000/svg" | ||||
|    xmlns="http://www.w3.org/2000/svg" | ||||
|    id="svg8" | ||||
|    version="1.1" | ||||
|    viewBox="0 0 135.46667 135.46667" | ||||
|    height="512" | ||||
|    width="512"> | ||||
|   <defs | ||||
|      id="defs2" /> | ||||
|   <metadata | ||||
|      id="metadata5"> | ||||
|     <rdf:RDF> | ||||
|       <cc:Work | ||||
|          rdf:about=""> | ||||
|         <dc:format>image/svg+xml</dc:format> | ||||
|         <dc:type | ||||
|            rdf:resource="http://purl.org/dc/dcmitype/StillImage" /> | ||||
|         <dc:title></dc:title> | ||||
|       </cc:Work> | ||||
|     </rdf:RDF> | ||||
|   </metadata> | ||||
|   <g | ||||
|      style="fill:#2fa3bc;fill-opacity:1" | ||||
|      transform="translate(-30.809093,-111.78601)" | ||||
|      id="layer1"> | ||||
|     <g | ||||
|        style="fill:#2fa3bc;fill-opacity:1" | ||||
|        transform="matrix(1.096096,0,0,1.096096,-2.960633,-44.023579)" | ||||
|        id="g4502"> | ||||
|       <g | ||||
|          id="g5125" | ||||
|          transform="translate(-1.3333333e-6,-1.3439941e-6)" | ||||
|          style="fill:#2fa3bc;fill-opacity:1"> | ||||
|         <g | ||||
|            aria-label="Mi" | ||||
|            style="font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;font-size:141.03404236px;line-height:476.69509888px;font-family:'OTADESIGN Rounded';-inkscape-font-specification:'OTADESIGN Rounded';letter-spacing:0px;word-spacing:0px;fill:#2fa3bc;fill-opacity:1;stroke:none;stroke-width:0.28950602px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" | ||||
|            id="text4489" | ||||
|            transform="matrix(0.91391326,0,0,0.91391326,7.9719907,17.595761)"> | ||||
|           <path | ||||
|              id="path5210" | ||||
|              transform="matrix(0.26412464,0,0,0.26412464,24.988264,136.28626)" | ||||
|              d="m 62.474609,76.585938 c -7.47555,0 -14.595784,1.246427 -21.359375,3.738281 C 29.011968,84.595952 19.044417,92.249798 11.212891,103.28516 3.7373405,113.96451 0,125.88934 0,139.06055 v 233.8789 c 0,17.08697 6.0510264,31.85913 18.154297,44.31836 12.459246,12.10327 27.233346,18.15625 44.320312,18.15625 17.442947,0 32.215089,-6.05298 44.318361,-18.15625 12.45925,-12.45923 18.68945,-27.23139 18.68945,-44.31836 V 330.4082 c 0.13441,-9.21122 9.6225,-6.79429 14.41797,0 8.98111,15.55395 28.02226,28.91242 50.19141,28.83594 22.16915,-0.0764 40.58194,-11.03699 50.19336,-28.83594 3.63981,-4.29263 13.89902,-11.60675 14.95117,0 v 42.53125 c 0,17.08697 6.05102,31.85913 18.15429,44.31836 12.45923,12.10327 27.23335,18.15625 44.32032,18.15625 17.44294,0 32.21509,-6.05298 44.31836,-18.15625 12.45923,-12.45923 18.68945,-27.23139 18.68945,-44.31836 v -233.8789 c 0,-13.17121 -3.9146,-25.09604 -11.74609,-35.77539 -7.47557,-11.035362 -17.26588,-18.689208 -29.36914,-22.960941 -7.11956,-2.491854 -14.23982,-3.738281 -21.35938,-3.738281 -19.22286,0 -35.41865,7.476649 -48.58984,22.427734 l -63.40235,74.199218 c -1.42391,1.06791 -6.14093,9.23242 -16.16015,9.23242 -10.01923,0 -14.20109,-8.16451 -15.625,-9.23242 L 110.53125,99.013672 C 97.716024,84.062587 81.697447,76.585938 62.474609,76.585938 Z m 395.060551,0 c -14.9511,-10e-7 -27.76596,5.340179 -38.44532,16.019531 -10.32338,10.323381 -15.48437,22.961011 -15.48437,37.912111 0,14.9511 5.16099,27.76596 15.48437,38.44531 10.67936,10.32338 23.49422,15.48633 38.44532,15.48633 14.95109,0 27.76596,-5.16295 38.44531,-15.48633 C 506.65982,158.28354 512,145.46868 512,130.51758 512,115.56648 506.65982,102.92885 495.98047,92.605469 485.30112,81.926117 472.48625,76.585938 457.53516,76.585938 Z m 0.5332,118.541012 c -14.9511,0 -27.76596,5.34018 -38.44531,16.01953 -10.67936,10.67936 -16.01758,23.49422 -16.01758,38.44532 v 131.89062 c 0,14.9511 5.33822,27.76596 16.01758,38.44531 10.67935,10.32339 23.49421,15.48633 38.44531,15.48633 14.9511,0 27.58873,-5.16294 37.91211,-15.48633 C 506.65982,409.24838 512,396.43352 512,381.48242 V 249.5918 c 0,-14.9511 -5.34018,-27.76596 -16.01953,-38.44532 -10.32338,-10.67935 -22.96101,-16.01953 -37.91211,-16.01953 z" | ||||
|              style="font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;font-family:'OTADESIGN Rounded';-inkscape-font-specification:'OTADESIGN Rounded';fill:#2fa3bc;fill-opacity:1;stroke-width:1.09609616px" /> | ||||
|         </g> | ||||
|       </g> | ||||
|     </g> | ||||
|   </g> | ||||
| </svg> | ||||
| After Width: | Height: | Size: 4.1 KiB | 
							
								
								
									
										
											BIN
										
									
								
								assets/icons/128.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 1.5 KiB | 
							
								
								
									
										
											BIN
										
									
								
								assets/icons/16.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 430 B | 
							
								
								
									
										
											BIN
										
									
								
								assets/icons/192.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 2.0 KiB | 
							
								
								
									
										
											BIN
										
									
								
								assets/icons/256.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 2.5 KiB | 
							
								
								
									
										
											BIN
										
									
								
								assets/icons/32.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 671 B | 
							
								
								
									
										
											BIN
										
									
								
								assets/icons/64.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 1015 B | 
							
								
								
									
										51
									
								
								assets/mi.svg
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,51 @@ | ||||
| <?xml version="1.0" encoding="UTF-8" standalone="no"?> | ||||
| <svg | ||||
|    xmlns:dc="http://purl.org/dc/elements/1.1/" | ||||
|    xmlns:cc="http://creativecommons.org/ns#" | ||||
|    xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" | ||||
|    xmlns:svg="http://www.w3.org/2000/svg" | ||||
|    xmlns="http://www.w3.org/2000/svg" | ||||
|    id="svg8" | ||||
|    version="1.1" | ||||
|    viewBox="0 0 135.46667 135.46667" | ||||
|    height="512" | ||||
|    width="512"> | ||||
|   <defs | ||||
|      id="defs2" /> | ||||
|   <metadata | ||||
|      id="metadata5"> | ||||
|     <rdf:RDF> | ||||
|       <cc:Work | ||||
|          rdf:about=""> | ||||
|         <dc:format>image/svg+xml</dc:format> | ||||
|         <dc:type | ||||
|            rdf:resource="http://purl.org/dc/dcmitype/StillImage" /> | ||||
|         <dc:title></dc:title> | ||||
|       </cc:Work> | ||||
|     </rdf:RDF> | ||||
|   </metadata> | ||||
|   <g | ||||
|      transform="translate(-30.809093,-111.78601)" | ||||
|      id="layer1"> | ||||
|     <g | ||||
|        transform="matrix(1.096096,0,0,1.096096,-2.960633,-44.023579)" | ||||
|        id="g4502"> | ||||
|       <g | ||||
|          id="g5125" | ||||
|          transform="translate(-1.3333333e-6,-1.3439941e-6)" | ||||
|          style="fill:#000000;fill-opacity:1"> | ||||
|         <g | ||||
|            aria-label="Mi" | ||||
|            style="font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;font-size:141.03404236px;line-height:476.69509888px;font-family:'OTADESIGN Rounded';-inkscape-font-specification:'OTADESIGN Rounded';letter-spacing:0px;word-spacing:0px;fill:#000000;fill-opacity:1;stroke:none;stroke-width:0.28950602px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" | ||||
|            id="text4489" | ||||
|            transform="matrix(0.91391326,0,0,0.91391326,7.9719907,17.595761)"> | ||||
|           <path | ||||
|              id="path5210" | ||||
|              transform="matrix(0.26412464,0,0,0.26412464,24.988264,136.28626)" | ||||
|              d="m 62.474609,76.585938 c -7.47555,0 -14.595784,1.246427 -21.359375,3.738281 C 29.011968,84.595952 19.044417,92.249798 11.212891,103.28516 3.7373405,113.96451 0,125.88934 0,139.06055 v 233.8789 c 0,17.08697 6.0510264,31.85913 18.154297,44.31836 12.459246,12.10327 27.233346,18.15625 44.320312,18.15625 17.442947,0 32.215089,-6.05298 44.318361,-18.15625 12.45925,-12.45923 18.68945,-27.23139 18.68945,-44.31836 V 330.4082 c 0.13441,-9.21122 9.6225,-6.79429 14.41797,0 8.98111,15.55395 28.02226,28.91242 50.19141,28.83594 22.16915,-0.0764 40.58194,-11.03699 50.19336,-28.83594 3.63981,-4.29263 13.89902,-11.60675 14.95117,0 v 42.53125 c 0,17.08697 6.05102,31.85913 18.15429,44.31836 12.45923,12.10327 27.23335,18.15625 44.32032,18.15625 17.44294,0 32.21509,-6.05298 44.31836,-18.15625 12.45923,-12.45923 18.68945,-27.23139 18.68945,-44.31836 v -233.8789 c 0,-13.17121 -3.9146,-25.09604 -11.74609,-35.77539 -7.47557,-11.035362 -17.26588,-18.689208 -29.36914,-22.960941 -7.11956,-2.491854 -14.23982,-3.738281 -21.35938,-3.738281 -19.22286,0 -35.41865,7.476649 -48.58984,22.427734 l -63.40235,74.199218 c -1.42391,1.06791 -6.14093,9.23242 -16.16015,9.23242 -10.01923,0 -14.20109,-8.16451 -15.625,-9.23242 L 110.53125,99.013672 C 97.716024,84.062587 81.697447,76.585938 62.474609,76.585938 Z m 395.060551,0 c -14.9511,-10e-7 -27.76596,5.340179 -38.44532,16.019531 -10.32338,10.323381 -15.48437,22.961011 -15.48437,37.912111 0,14.9511 5.16099,27.76596 15.48437,38.44531 10.67936,10.32338 23.49422,15.48633 38.44532,15.48633 14.95109,0 27.76596,-5.16295 38.44531,-15.48633 C 506.65982,158.28354 512,145.46868 512,130.51758 512,115.56648 506.65982,102.92885 495.98047,92.605469 485.30112,81.926117 472.48625,76.585938 457.53516,76.585938 Z m 0.5332,118.541012 c -14.9511,0 -27.76596,5.34018 -38.44531,16.01953 -10.67936,10.67936 -16.01758,23.49422 -16.01758,38.44532 v 131.89062 c 0,14.9511 5.33822,27.76596 16.01758,38.44531 10.67935,10.32339 23.49421,15.48633 38.44531,15.48633 14.9511,0 27.58873,-5.16294 37.91211,-15.48633 C 506.65982,409.24838 512,396.43352 512,381.48242 V 249.5918 c 0,-14.9511 -5.34018,-27.76596 -16.01953,-38.44532 -10.32338,-10.67935 -22.96101,-16.01953 -37.91211,-16.01953 z" | ||||
|              style="font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;font-family:'OTADESIGN Rounded';-inkscape-font-specification:'OTADESIGN Rounded';fill:#000000;fill-opacity:1;stroke-width:1.09609616px" /> | ||||
|         </g> | ||||
|       </g> | ||||
|     </g> | ||||
|   </g> | ||||
| </svg> | ||||
| After Width: | Height: | Size: 4.1 KiB | 
| Before Width: | Height: | Size: 148 KiB After Width: | Height: | Size: 148 KiB | 
| @@ -1,67 +0,0 @@ | ||||
| <?xml version="1.0" encoding="UTF-8" standalone="no"?> | ||||
| <svg | ||||
|    xmlns:dc="http://purl.org/dc/elements/1.1/" | ||||
|    xmlns:cc="http://creativecommons.org/ns#" | ||||
|    xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" | ||||
|    xmlns:svg="http://www.w3.org/2000/svg" | ||||
|    xmlns="http://www.w3.org/2000/svg" | ||||
|    id="svg10" | ||||
|    version="1.1" | ||||
|    viewBox="0 0 162.642 54.261" | ||||
|    height="205.08" | ||||
|    width="614.71"> | ||||
|   <metadata | ||||
|      id="metadata16"> | ||||
|     <rdf:RDF> | ||||
|       <cc:Work | ||||
|          rdf:about=""> | ||||
|         <dc:format>image/svg+xml</dc:format> | ||||
|         <dc:type | ||||
|            rdf:resource="http://purl.org/dc/dcmitype/StillImage" /> | ||||
|         <dc:title></dc:title> | ||||
|       </cc:Work> | ||||
|     </rdf:RDF> | ||||
|   </metadata> | ||||
| 	<style> | ||||
| 		#g8 {  | ||||
|     	animation-name: floating; | ||||
|     	animation-duration: 3s; | ||||
|     	animation-iteration-count: infinite; | ||||
|    	 	animation-timing-function: ease-in-out; | ||||
| 		} | ||||
|   | ||||
| 		@keyframes floating { | ||||
|     	0% { transform: translate(0,  0px); } | ||||
|     	50% { transform: translate(0, -5px); } | ||||
|     	100% { transform: translate(0, 0px); } | ||||
| 		} | ||||
| 	</style> | ||||
| 	<linearGradient id="myGradient" gradientTransform="rotate(90)"> | ||||
|       <stop offset="5%"  stop-color="#A1CA03" /> | ||||
|       <stop offset="95%" stop-color="#91BA03" /> | ||||
|     </linearGradient> | ||||
|   <defs | ||||
|      id="defs14" /> | ||||
|   <g | ||||
|      id="g8" | ||||
|      fill="url('#myGradient')" | ||||
|      word-spacing="0" | ||||
|      letter-spacing="0" | ||||
|      font-family="OTADESIGN Rounded" | ||||
|      font-weight="400"> | ||||
|     <g | ||||
|        id="g4" | ||||
|        style="line-height:476.69509888px;-inkscape-font-specification:'OTADESIGN Rounded'"> | ||||
|       <path | ||||
|          id="path2" | ||||
|          font-size="141.034" | ||||
|          aria-label="Mi" | ||||
|          d="m 27.595,34.59 c -1.676,0.006 -3.115,-1.004 -3.793,-2.179 -0.363,-0.513 -1.08,-0.696 -1.09,0 v 3.214 c 0,1.291 -0.47,2.408 -1.412,3.35 -0.915,0.914 -2.031,1.371 -3.35,1.371 -1.29,0 -2.407,-0.457 -3.349,-1.372 -0.914,-0.941 -1.372,-2.058 -1.372,-3.349 V 17.95 c 0,-0.995 0.283,-1.896 0.848,-2.703 0.591,-0.834 1.345,-1.413 2.26,-1.735 0.516591,-0.189385 1.062793,-0.285215 1.613,-0.283 1.453,0 2.664,0.565 3.632,1.695 l 4.832,5.608 c 0.108,0.08 0.424,0.697 1.18,0.697 0.758,0 1.115,-0.617 1.222,-0.698 l 4.791,-5.607 c 0.996,-1.13 2.22,-1.695 3.673,-1.695 0.538,0 1.076,0.094 1.614,0.283 0.914,0.322 1.654,0.9 2.22,1.735 0.591,0.807 0.887,1.708 0.887,2.703 v 17.675 c 0,1.291 -0.47,2.408 -1.412,3.35 -0.915,0.914 -2.032,1.371 -3.35,1.371 -1.291,0 -2.407,-0.457 -3.35,-1.372 -0.914,-0.941 -1.371,-2.058 -1.371,-3.349 v -3.214 c -0.08,-0.877 -0.855,-0.324 -1.13,0 -0.726,1.345 -2.118,2.173 -3.793,2.18 z M 47.806,21.38 c -1.13,0 -2.098333,-0.39 -2.905,-1.17 -0.78,-0.806667 -1.17,-1.775 -1.17,-2.905 0,-1.13 0.39,-2.085 1.17,-2.865 0.806667,-0.806667 1.775,-1.21 2.905,-1.21 1.13,0 2.098667,0.403333 2.906,1.21 0.806667,0.78 1.21,1.735 1.21,2.865 0,1.13 -0.403333,2.098333 -1.21,2.905 -0.807333,0.78 -1.776,1.17 -2.906,1.17 z m 0.04,0.808 c 1.13,0 2.085333,0.403333 2.866,1.21 0.806667,0.806667 1.21,1.775333 1.21,2.906 v 9.967 c 0,1.13 -0.403333,2.098333 -1.21,2.905 -0.78,0.78 -1.735333,1.17 -2.866,1.17 -1.129333,0 -2.097667,-0.39 -2.905,-1.17 -0.806667,-0.806667 -1.21,-1.775 -1.21,-2.905 v -9.967 c 0,-1.13 0.403333,-2.098667 1.21,-2.906 0.806667,-0.806667 1.775,-1.21 2.905,-1.21 z" | ||||
|          style="font-size:141.03399658px;-inkscape-font-specification:'OTADESIGN Rounded'" /> | ||||
|     </g> | ||||
|     <path | ||||
|        id="path6" | ||||
|        d="M60.925 27.24q.968.243 2.42.525 2.42.403 3.792 1.29 2.582 1.695 2.582 5.083 0 2.743-1.815 4.478-2.098 2.017-5.85 2.017-2.742 0-6.13-.767-1.09-.242-1.776-1.089-.645-.847-.645-1.896 0-1.29.887-2.178.928-.928 2.179-.928.363 0 .685.081 1.17.242 4.478.605.444 0 .968-.04.202 0 .202-.242.04-.202-.242-.283-1.372-.242-2.542-.524-1.33-.282-1.896-.484-1.129-.323-1.895-.847-2.582-1.694-2.622-5.083 0-2.702 1.855-4.477 2.26-2.179 6.414-1.977 2.783.121 5.567.726 1.048.242 1.734 1.09.686.846.686 1.936 0 1.25-.928 2.178-.887.887-2.178.887-.323 0-.645-.08-1.17-.242-4.518-.565-.404-.04-.767 0-.323.04-.323.242.04.242.323.323zm17.555 0q.968.243 2.42.525 2.42.403 3.792 1.29 2.581 1.695 2.581 5.083 0 2.743-1.815 4.478-2.098 2.017-5.849 2.017-2.743 0-6.131-.767-1.09-.242-1.775-1.089-.646-.847-.646-1.896 0-1.29.888-2.178.927-.928 2.178-.928.363 0 .686.081 1.17.242 4.477.605.444 0 .968-.04.202 0 .202-.242.04-.202-.242-.283-1.371-.242-2.541-.524-1.331-.282-1.896-.484-1.13-.323-1.896-.847-2.582-1.694-2.622-5.083 0-2.702 1.855-4.477 2.26-2.179 6.414-1.977 2.784.121 5.567.726 1.049.242 1.735 1.09.685.846.685 1.936 0 1.25-.927 2.178-.888.887-2.179.887-.322 0-.645-.08-1.17-.242-4.518-.565-.403-.04-.767 0-.322.04-.322.242.04.242.322.323zm26.075 3.335q.12.08 2.864 2.783 1.25 1.21 1.25 2.945 0 1.613-1.17 2.864-1.17 1.21-2.904 1.21-1.654 0-2.864-1.17l-4.034-3.913q-.161-.12-.323-.12-.322 0-.322 1.21 0 1.694-1.21 2.904-1.21 1.17-2.905 1.17-1.694 0-2.904-1.17-1.17-1.21-1.17-2.905V17.586q0-1.694 1.17-2.864 1.21-1.21 2.904-1.21t2.904 1.21q1.21 1.17 1.21 2.864v6.293q0 .403.283.524.242.121.524-.08.162-.081 4.841-3.188 1.049-.645 2.259-.645 2.219 0 3.429 1.815.645 1.05.645 2.26 0 2.218-1.815 3.428l-2.541 1.614v.04l-.081.04q-.565.363-.04.888zm15.599 10.058q-4.195 0-7.18-2.945-2.945-2.985-2.945-7.18 0-4.155 2.945-7.1 2.985-2.985 7.18-2.985 4.155 0 6.979 2.784.928.927.928 2.259 0 1.33-.928 2.259l-4.68 4.639q-1.008 1.008-2.016 1.008-1.453 0-2.26-.807-.806-.807-.806-2.138 0-1.29.928-2.218l.806-.847q.162-.121.081-.243-.12-.08-.323-.04-.806.202-1.371.807-1.13 1.09-1.13 2.622 0 1.573 1.09 2.703 1.13 1.089 2.702 1.089 1.533 0 2.622-1.13.928-.927 2.26-.927 1.33 0 2.258.927.928.928.928 2.26 0 1.33-.928 2.258-2.985 2.945-7.14 2.945zm29.259-15.786v5.607q0 .564-.08 1.21v7.382q0 4.518-2.744 7.22-2.702 2.703-7.301 2.703-2.662 0-4.8-1.008-2.138-.968-2.138-3.348 0-.807.363-1.533.968-2.179 3.348-2.179.565 0 1.573.323 1.009.323 1.654.323 1.694 0 2.219-.726.201-.283.08-.444-.161-.242-.564-.161-.686.12-1.493.12-4.074 0-6.979-2.904-2.904-2.904-2.904-6.978v-5.607q0-1.695 1.17-2.864 1.21-1.21 2.904-1.21t2.905 1.21q1.21 1.17 1.21 2.864v5.607q0 .685.484 1.21.524.484 1.21.484.726 0 1.21-.484.484-.525.484-1.21v-5.607q0-1.695 1.21-2.864 1.21-1.21 2.905-1.21 1.694 0 2.864 1.21 1.21 1.17 1.21 2.864z" | ||||
|        style="line-height:136.34428406px;-inkscape-font-specification:'OTADESIGN Rounded'" /> | ||||
|   </g> | ||||
| </svg> | ||||
| Before Width: | Height: | Size: 6.1 KiB | 
							
								
								
									
										9
									
								
								binding.gyp
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,9 @@ | ||||
| { | ||||
| 	'targets': [ | ||||
| 		{ | ||||
| 			'target_name': 'crypto_key', | ||||
| 			'sources': ['src/crypto_key.cc'], | ||||
| 			'include_dirs': ['<!(node -e "require(\'nan\')")'] | ||||
| 		} | ||||
| 	] | ||||
| } | ||||
| @@ -1,3 +0,0 @@ | ||||
| apiVersion: v2 | ||||
| name: misskey | ||||
| version: 0.0.0 | ||||
| @@ -1,165 +0,0 @@ | ||||
| #━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ | ||||
| # Misskey configuration | ||||
| #━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ | ||||
|  | ||||
| #   ┌─────┐ | ||||
| #───┘ URL └───────────────────────────────────────────────────── | ||||
|  | ||||
| # Final accessible URL seen by a user. | ||||
| # url: https://example.tld/ | ||||
|  | ||||
| # ONCE YOU HAVE STARTED THE INSTANCE, DO NOT CHANGE THE | ||||
| # URL SETTINGS AFTER THAT! | ||||
|  | ||||
| #   ┌───────────────────────┐ | ||||
| #───┘ Port and TLS settings └─────────────────────────────────── | ||||
|  | ||||
| # | ||||
| # Misskey supports two deployment options for public. | ||||
| # | ||||
|  | ||||
| # Option 1: With Reverse Proxy | ||||
| # | ||||
| #                 +----- https://example.tld/ ------------+ | ||||
| #   +------+      |+-------------+      +----------------+| | ||||
| #   | User | ---> || Proxy (443) | ---> | Misskey (3000) || | ||||
| #   +------+      |+-------------+      +----------------+| | ||||
| #                 +---------------------------------------+ | ||||
| # | ||||
| #   You need to setup reverse proxy. (eg. nginx) | ||||
| #   You do not define 'https' section. | ||||
|  | ||||
| # Option 2: Standalone | ||||
| # | ||||
| #                 +- https://example.tld/ -+ | ||||
| #   +------+      |   +---------------+    | | ||||
| #   | User | ---> |   | Misskey (443) |    | | ||||
| #   +------+      |   +---------------+    | | ||||
| #                 +------------------------+ | ||||
| # | ||||
| #   You need to run Misskey as root. | ||||
| #   You need to set Certificate in 'https' section. | ||||
|  | ||||
| # To use option 1, uncomment below line. | ||||
| port: 3000 # A port that your Misskey server should listen. | ||||
|  | ||||
| # To use option 2, uncomment below lines. | ||||
| #port: 443 | ||||
|  | ||||
| #https: | ||||
| #  # path for certification | ||||
| #  key: /etc/letsencrypt/live/example.tld/privkey.pem | ||||
| #  cert: /etc/letsencrypt/live/example.tld/fullchain.pem | ||||
|  | ||||
| #   ┌──────────────────────────┐ | ||||
| #───┘ PostgreSQL configuration └──────────────────────────────── | ||||
|  | ||||
| db: | ||||
|   host: localhost | ||||
|   port: 5432 | ||||
|  | ||||
|   # Database name | ||||
|   db: misskey | ||||
|  | ||||
|   # Auth | ||||
|   user: example-misskey-user | ||||
|   pass: example-misskey-pass | ||||
|  | ||||
|   # Whether disable Caching queries | ||||
|   #disableCache: true | ||||
|  | ||||
|   # Extra Connection options | ||||
|   #extra: | ||||
|   #  ssl: true | ||||
|  | ||||
| #   ┌─────────────────────┐ | ||||
| #───┘ Redis configuration └───────────────────────────────────── | ||||
|  | ||||
| redis: | ||||
|   host: localhost | ||||
|   port: 6379 | ||||
|   #pass: example-pass | ||||
|   #prefix: example-prefix | ||||
|   #db: 1 | ||||
|  | ||||
| #   ┌─────────────────────────────┐ | ||||
| #───┘ Elasticsearch configuration └───────────────────────────── | ||||
|  | ||||
| #elasticsearch: | ||||
| #  host: localhost | ||||
| #  port: 9200 | ||||
| #  ssl: false | ||||
| #  user: | ||||
| #  pass: | ||||
|  | ||||
| #   ┌───────────────┐ | ||||
| #───┘ ID generation └─────────────────────────────────────────── | ||||
|  | ||||
| # You can select the ID generation method. | ||||
| # You don't usually need to change this setting, but you can | ||||
| # change it according to your preferences. | ||||
|  | ||||
| # Available methods: | ||||
| # aid ... Short, Millisecond accuracy | ||||
| # meid ... Similar to ObjectID, Millisecond accuracy | ||||
| # ulid ... Millisecond accuracy | ||||
| # objectid ... This is left for backward compatibility | ||||
|  | ||||
| # ONCE YOU HAVE STARTED THE INSTANCE, DO NOT CHANGE THE | ||||
| # ID SETTINGS AFTER THAT! | ||||
|  | ||||
| id: "aid" | ||||
| #   ┌─────────────────────┐ | ||||
| #───┘ Other configuration └───────────────────────────────────── | ||||
|  | ||||
| # Whether disable HSTS | ||||
| #disableHsts: true | ||||
|  | ||||
| # Number of worker processes | ||||
| #clusterLimit: 1 | ||||
|  | ||||
| # Job concurrency per worker | ||||
| # deliverJobConcurrency: 128 | ||||
| # inboxJobConcurrency: 16 | ||||
|  | ||||
| # Job rate limiter | ||||
| # deliverJobPerSec: 128 | ||||
| # inboxJobPerSec: 16 | ||||
|  | ||||
| # Job attempts | ||||
| # deliverJobMaxAttempts: 12 | ||||
| # inboxJobMaxAttempts: 8 | ||||
|  | ||||
| # IP address family used for outgoing request (ipv4, ipv6 or dual) | ||||
| #outgoingAddressFamily: ipv4 | ||||
|  | ||||
| # Syslog option | ||||
| #syslog: | ||||
| #  host: localhost | ||||
| #  port: 514 | ||||
|  | ||||
| # Proxy for HTTP/HTTPS | ||||
| #proxy: http://127.0.0.1:3128 | ||||
|  | ||||
| #proxyBypassHosts: [ | ||||
| #  'example.com', | ||||
| #  '192.0.2.8' | ||||
| #] | ||||
|  | ||||
| # Proxy for SMTP/SMTPS | ||||
| #proxySmtp: http://127.0.0.1:3128   # use HTTP/1.1 CONNECT | ||||
| #proxySmtp: socks4://127.0.0.1:1080 # use SOCKS4 | ||||
| #proxySmtp: socks5://127.0.0.1:1080 # use SOCKS5 | ||||
|  | ||||
| # Media Proxy | ||||
| #mediaProxy: https://example.com/proxy | ||||
|  | ||||
| # Sign to ActivityPub GET request (default: false) | ||||
| #signToActivityPubGet: true | ||||
|  | ||||
| #allowedPrivateNetworks: [ | ||||
| #  '127.0.0.1/32' | ||||
| #] | ||||
|  | ||||
| # Upload or download file size limits (bytes) | ||||
| #maxFileSize: 262144000 | ||||
| @@ -1,8 +0,0 @@ | ||||
| apiVersion: v1 | ||||
| kind: ConfigMap | ||||
| metadata: | ||||
|   name: {{ include "misskey.fullname" . }}-configuration | ||||
| data: | ||||
|   default.yml: |- | ||||
|     {{ .Files.Get "files/default.yml"|nindent 4 }} | ||||
|     url: {{ .Values.url }} | ||||
| @@ -1,47 +0,0 @@ | ||||
| apiVersion: apps/v1 | ||||
| kind: Deployment | ||||
| metadata: | ||||
|   name: {{ include "misskey.fullname" . }} | ||||
|   labels: | ||||
| 		{{- include "misskey.labels" . | nindent 4 }} | ||||
| spec: | ||||
|   selector: | ||||
|     matchLabels: | ||||
| 			{{- include "misskey.selectorLabels" . | nindent 6 }} | ||||
|   replicas: 1 | ||||
|   template: | ||||
|     metadata: | ||||
|       labels: | ||||
| 				{{- include "misskey.selectorLabels" . | nindent 8 }} | ||||
|     spec: | ||||
|       containers: | ||||
|         - name: misskey | ||||
|           image: {{ .Values.image }} | ||||
|           env: | ||||
|             - name: NODE_ENV | ||||
|               value: {{ .Values.environment }} | ||||
|           volumeMounts: | ||||
|             - name: {{ include "misskey.fullname" . }}-configuration | ||||
|               mountPath: /misskey/.config | ||||
|               readOnly: true | ||||
|           ports: | ||||
|             - containerPort: 3000 | ||||
|         - name: postgres | ||||
|           image: postgres:14-alpine | ||||
|           env: | ||||
|             - name: POSTGRES_USER | ||||
|               value: "example-misskey-user" | ||||
|             - name: POSTGRES_PASSWORD | ||||
|               value: "example-misskey-pass" | ||||
|             - name: POSTGRES_DB | ||||
|               value: "misskey" | ||||
|           ports: | ||||
|             - containerPort: 5432 | ||||
|         - name: redis | ||||
|           image: redis:alpine | ||||
|           ports: | ||||
|             - containerPort: 6379 | ||||
|       volumes: | ||||
|         - name: {{ include "misskey.fullname" . }}-configuration | ||||
|           configMap: | ||||
|             name: {{ include "misskey.fullname" . }}-configuration | ||||
| @@ -1,14 +0,0 @@ | ||||
| apiVersion: v1 | ||||
| kind: Service | ||||
| metadata: | ||||
|   name: {{ include "misskey.fullname" . }} | ||||
|   annotations: | ||||
|     dev.okteto.com/auto-ingress: "true" | ||||
| spec: | ||||
|   type: ClusterIP | ||||
|   ports: | ||||
|     - port: 3000 | ||||
|       protocol: TCP | ||||
|       name: http | ||||
|   selector: | ||||
| 		{{- include "misskey.selectorLabels" . | nindent 4 }} | ||||
| @@ -1,62 +0,0 @@ | ||||
| {{/* | ||||
| Expand the name of the chart. | ||||
| */}} | ||||
| {{- define "misskey.name" -}} | ||||
| {{- default .Chart.Name .Values.nameOverride | trunc 63 | trimSuffix "-" }} | ||||
| {{- end }} | ||||
|  | ||||
| {{/* | ||||
| Create a default fully qualified app name. | ||||
| We truncate at 63 chars because some Kubernetes name fields are limited to this (by the DNS naming spec). | ||||
| If release name contains chart name it will be used as a full name. | ||||
| */}} | ||||
| {{- define "misskey.fullname" -}} | ||||
| {{- if .Values.fullnameOverride }} | ||||
| {{- .Values.fullnameOverride | trunc 63 | trimSuffix "-" }} | ||||
| {{- else }} | ||||
| {{- $name := default .Chart.Name .Values.nameOverride }} | ||||
| {{- if contains $name .Release.Name }} | ||||
| {{- .Release.Name | trunc 63 | trimSuffix "-" }} | ||||
| {{- else }} | ||||
| {{- printf "%s-%s" .Release.Name $name | trunc 63 | trimSuffix "-" }} | ||||
| {{- end }} | ||||
| {{- end }} | ||||
| {{- end }} | ||||
|  | ||||
| {{/* | ||||
| Create chart name and version as used by the chart label. | ||||
| */}} | ||||
| {{- define "misskey.chart" -}} | ||||
| {{- printf "%s-%s" .Chart.Name .Chart.Version | replace "+" "_" | trunc 63 | trimSuffix "-" }} | ||||
| {{- end }} | ||||
|  | ||||
| {{/* | ||||
| Common labels | ||||
| */}} | ||||
| {{- define "misskey.labels" -}} | ||||
| helm.sh/chart: {{ include "misskey.chart" . }} | ||||
| {{ include "misskey.selectorLabels" . }} | ||||
| {{- if .Chart.AppVersion }} | ||||
| app.kubernetes.io/version: {{ .Chart.AppVersion | quote }} | ||||
| {{- end }} | ||||
| app.kubernetes.io/managed-by: {{ .Release.Service }} | ||||
| {{- end }} | ||||
|  | ||||
| {{/* | ||||
| Selector labels | ||||
| */}} | ||||
| {{- define "misskey.selectorLabels" -}} | ||||
| app.kubernetes.io/name: {{ include "misskey.name" . }} | ||||
| app.kubernetes.io/instance: {{ .Release.Name }} | ||||
| {{- end }} | ||||
|  | ||||
| {{/* | ||||
| Create the name of the service account to use | ||||
| */}} | ||||
| {{- define "misskey.serviceAccountName" -}} | ||||
| {{- if .Values.serviceAccount.create }} | ||||
| {{- default (include "misskey.fullname" .) .Values.serviceAccount.name }} | ||||
| {{- else }} | ||||
| {{- default "default" .Values.serviceAccount.name }} | ||||
| {{- end }} | ||||
| {{- end }} | ||||
| @@ -1,3 +0,0 @@ | ||||
| url: https://example.tld/ | ||||
| image: okteto.dev/misskey | ||||
| environment: production | ||||
							
								
								
									
										23
									
								
								cli/mark-admin.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,23 @@ | ||||
| const mongo = require('mongodb'); | ||||
| const User = require('../built/models/user').default; | ||||
|  | ||||
| const args = process.argv.slice(2); | ||||
|  | ||||
| const user = args[0]; | ||||
|  | ||||
| const q = user.startsWith('@') ? { | ||||
| 	username: user.split('@')[1], | ||||
| 	host: user.split('@')[2] || null | ||||
| } : { _id: new mongo.ObjectID(user) }; | ||||
|  | ||||
| console.log(`Mark as admin ${user}...`); | ||||
|  | ||||
| User.update(q, { | ||||
| 	$set: { | ||||
| 		isAdmin: true | ||||
| 	} | ||||
| }).then(() => { | ||||
| 	console.log(`Done ${user}`); | ||||
| }, e => { | ||||
| 	console.error(e); | ||||
| }); | ||||
							
								
								
									
										57
									
								
								cli/migration/2.0.0.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,57 @@ | ||||
| // for Node.js interpret | ||||
|  | ||||
| const chalk = require('chalk'); | ||||
| const sequential = require('promise-sequential'); | ||||
|  | ||||
| const { default: User } = require('../../built/models/user'); | ||||
| const { default: DriveFile } = require('../../built/models/drive-file'); | ||||
|  | ||||
| async function main() { | ||||
| 	const promiseGens = []; | ||||
|  | ||||
| 	const count = await DriveFile.count({}); | ||||
|  | ||||
| 	let prev; | ||||
|  | ||||
| 	for (let i = 0; i < count; i++) { | ||||
| 		promiseGens.push(() => { | ||||
| 			const promise = new Promise(async (res, rej) => { | ||||
| 				const file = await DriveFile.findOne(prev ? { | ||||
| 					_id: { $gt: prev._id } | ||||
| 				} : {}, { | ||||
| 					sort: { | ||||
| 						_id: 1 | ||||
| 					} | ||||
| 				}); | ||||
|  | ||||
| 				prev = file; | ||||
|  | ||||
| 				const user = await User.findOne({ _id: file.metadata.userId }); | ||||
|  | ||||
| 				DriveFile.update({ | ||||
| 					_id: file._id | ||||
| 				}, { | ||||
| 					$set: { | ||||
| 						'metadata._user': { | ||||
| 							host: user.host | ||||
| 						} | ||||
| 					} | ||||
| 				}).then(() => { | ||||
| 					res([i, file]); | ||||
| 				}).catch(rej); | ||||
| 			}); | ||||
|  | ||||
| 			promise.then(([i, file]) => { | ||||
| 				console.log(chalk`{gray ${i}} {green done: {bold ${file._id}} ${file.filename}}`); | ||||
| 			}); | ||||
|  | ||||
| 			return promise; | ||||
| 		}); | ||||
| 	} | ||||
|  | ||||
| 	return await sequential(promiseGens); | ||||
| } | ||||
|  | ||||
| main().then(() => { | ||||
| 	console.log('ALL DONE'); | ||||
| }).catch(console.error); | ||||
							
								
								
									
										71
									
								
								cli/migration/2.4.0.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,71 @@ | ||||
| // for Node.js interpret | ||||
|  | ||||
| const chalk = require('chalk'); | ||||
| const sequential = require('promise-sequential'); | ||||
|  | ||||
| const { default: User } = require('../../built/models/user'); | ||||
| const { default: DriveFile } = require('../../built/models/drive-file'); | ||||
|  | ||||
| async function main() { | ||||
| 	const promiseGens = []; | ||||
|  | ||||
| 	const count = await User.count({}); | ||||
|  | ||||
| 	let prev; | ||||
|  | ||||
| 	for (let i = 0; i < count; i++) { | ||||
| 		promiseGens.push(() => { | ||||
| 			const promise = new Promise(async (res, rej) => { | ||||
| 				const user = await User.findOne(prev ? { | ||||
| 					_id: { $gt: prev._id } | ||||
| 				} : {}, { | ||||
| 					sort: { | ||||
| 						_id: 1 | ||||
| 					} | ||||
| 				}); | ||||
|  | ||||
| 				prev = user; | ||||
|  | ||||
| 				const set = {}; | ||||
|  | ||||
| 				if (user.avatarId != null) { | ||||
| 					const file = await DriveFile.findOne({ _id: user.avatarId }); | ||||
|  | ||||
| 					if (file && file.metadata.properties.avgColor) { | ||||
| 						set.avatarColor = file.metadata.properties.avgColor; | ||||
| 					} | ||||
| 				} | ||||
|  | ||||
| 				if (user.bannerId != null) { | ||||
| 					const file = await DriveFile.findOne({ _id: user.bannerId }); | ||||
|  | ||||
| 					if (file && file.metadata.properties.avgColor) { | ||||
| 						set.bannerColor = file.metadata.properties.avgColor; | ||||
| 					} | ||||
| 				} | ||||
|  | ||||
| 				if (Object.keys(set).length === 0) return res([i, user]); | ||||
|  | ||||
| 				User.update({ | ||||
| 					_id: user._id | ||||
| 				}, { | ||||
| 					$set: set | ||||
| 				}).then(() => { | ||||
| 					res([i, user]); | ||||
| 				}).catch(rej); | ||||
| 			}); | ||||
|  | ||||
| 			promise.then(([i, user]) => { | ||||
| 				console.log(chalk`{gray ${i}} {green done: {bold ${user._id}} @${user.username}}`); | ||||
| 			}); | ||||
|  | ||||
| 			return promise; | ||||
| 		}); | ||||
| 	} | ||||
|  | ||||
| 	return await sequential(promiseGens); | ||||
| } | ||||
|  | ||||
| main().then(() => { | ||||
| 	console.log('ALL DONE'); | ||||
| }).catch(console.error); | ||||
							
								
								
									
										9
									
								
								cli/migration/5.0.0.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,9 @@ | ||||
| const { default: DriveFile } = require('../../built/models/drive-file'); | ||||
|  | ||||
| DriveFile.update({}, { | ||||
| 	$rename: { | ||||
| 		'metadata.isMetaOnly': 'metadata.withoutChunks' | ||||
| 	} | ||||
| }, { | ||||
| 	multi: true | ||||
| }); | ||||
							
								
								
									
										134
									
								
								cli/migration/7.0.0.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,134 @@ | ||||
| const { default: Stats } = require('../../built/models/stats'); | ||||
| const { default: User } = require('../../built/models/user'); | ||||
| const { default: Note } = require('../../built/models/note'); | ||||
| const { default: DriveFile } = require('../../built/models/drive-file'); | ||||
|  | ||||
| const now = new Date(); | ||||
| const y = now.getFullYear(); | ||||
| const m = now.getMonth(); | ||||
| const d = now.getDate(); | ||||
| const today = new Date(y, m, d); | ||||
|  | ||||
| async function main() { | ||||
| 	const localUsersCount = await User.count({ | ||||
| 		host: null | ||||
| 	}); | ||||
|  | ||||
| 	const remoteUsersCount = await User.count({ | ||||
| 		host: { $ne: null } | ||||
| 	}); | ||||
|  | ||||
| 	const localNotesCount = await Note.count({ | ||||
| 		'_user.host': null | ||||
| 	}); | ||||
|  | ||||
| 	const remoteNotesCount = await Note.count({ | ||||
| 		'_user.host': { $ne: null } | ||||
| 	}); | ||||
|  | ||||
| 	const localDriveFilesCount = await DriveFile.count({ | ||||
| 		'metadata._user.host': null | ||||
| 	}); | ||||
|  | ||||
| 	const remoteDriveFilesCount = await DriveFile.count({ | ||||
| 		'metadata._user.host': { $ne: null } | ||||
| 	}); | ||||
|  | ||||
| 	const localDriveFilesSize = await DriveFile | ||||
| 		.aggregate([{ | ||||
| 			$match: { | ||||
| 				'metadata._user.host': null, | ||||
| 				'metadata.deletedAt': { $exists: false } | ||||
| 			} | ||||
| 		}, { | ||||
| 			$project: { | ||||
| 				length: true | ||||
| 			} | ||||
| 		}, { | ||||
| 			$group: { | ||||
| 				_id: null, | ||||
| 				usage: { $sum: '$length' } | ||||
| 			} | ||||
| 		}]) | ||||
| 		.then(aggregates => { | ||||
| 			if (aggregates.length > 0) { | ||||
| 				return aggregates[0].usage; | ||||
| 			} | ||||
| 			return 0; | ||||
| 		}); | ||||
|  | ||||
| 	const remoteDriveFilesSize = await DriveFile | ||||
| 		.aggregate([{ | ||||
| 			$match: { | ||||
| 				'metadata._user.host': { $ne: null }, | ||||
| 				'metadata.deletedAt': { $exists: false } | ||||
| 			} | ||||
| 		}, { | ||||
| 			$project: { | ||||
| 				length: true | ||||
| 			} | ||||
| 		}, { | ||||
| 			$group: { | ||||
| 				_id: null, | ||||
| 				usage: { $sum: '$length' } | ||||
| 			} | ||||
| 		}]) | ||||
| 		.then(aggregates => { | ||||
| 			if (aggregates.length > 0) { | ||||
| 				return aggregates[0].usage; | ||||
| 			} | ||||
| 			return 0; | ||||
| 		}); | ||||
|  | ||||
| 	await Stats.insert({ | ||||
| 		date: today, | ||||
| 		users: { | ||||
| 			local: { | ||||
| 				total: localUsersCount, | ||||
| 				diff: 0 | ||||
| 			}, | ||||
| 			remote: { | ||||
| 				total: remoteUsersCount, | ||||
| 				diff: 0 | ||||
| 			} | ||||
| 		}, | ||||
| 		notes: { | ||||
| 			local: { | ||||
| 				total: localNotesCount, | ||||
| 				diff: 0, | ||||
| 				diffs: { | ||||
| 					normal: 0, | ||||
| 					reply: 0, | ||||
| 					renote: 0 | ||||
| 				} | ||||
| 			}, | ||||
| 			remote: { | ||||
| 				total: remoteNotesCount, | ||||
| 				diff: 0, | ||||
| 				diffs: { | ||||
| 					normal: 0, | ||||
| 					reply: 0, | ||||
| 					renote: 0 | ||||
| 				} | ||||
| 			} | ||||
| 		}, | ||||
| 		drive: { | ||||
| 			local: { | ||||
| 				totalCount: localDriveFilesCount, | ||||
| 				totalSize: localDriveFilesSize, | ||||
| 				diffCount: 0, | ||||
| 				diffSize: 0 | ||||
| 			}, | ||||
| 			remote: { | ||||
| 				totalCount: remoteDriveFilesCount, | ||||
| 				totalSize: remoteDriveFilesSize, | ||||
| 				diffCount: 0, | ||||
| 				diffSize: 0 | ||||
| 			} | ||||
| 		} | ||||
| 	}); | ||||
|  | ||||
| 	console.log('done'); | ||||
| } | ||||
|  | ||||
| main(); | ||||
							
								
								
									
										144
									
								
								cli/migration/8.0.0.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,144 @@ | ||||
| const { default: Stats } = require('../../built/models/stats'); | ||||
| const { default: User } = require('../../built/models/user'); | ||||
| const { default: Note } = require('../../built/models/note'); | ||||
| const { default: DriveFile } = require('../../built/models/drive-file'); | ||||
|  | ||||
| const now = new Date(); | ||||
| const y = now.getFullYear(); | ||||
| const m = now.getMonth(); | ||||
| const d = now.getDate(); | ||||
| const h = now.getHours(); | ||||
| const date = new Date(y, m, d, h); | ||||
|  | ||||
| async function main() { | ||||
| 	await Stats.update({}, { | ||||
| 		$set: { | ||||
| 			span: 'day' | ||||
| 		} | ||||
| 	}, { | ||||
| 		multi: true | ||||
| 	}); | ||||
|  | ||||
| 	const localUsersCount = await User.count({ | ||||
| 		host: null | ||||
| 	}); | ||||
|  | ||||
| 	const remoteUsersCount = await User.count({ | ||||
| 		host: { $ne: null } | ||||
| 	}); | ||||
|  | ||||
| 	const localNotesCount = await Note.count({ | ||||
| 		'_user.host': null | ||||
| 	}); | ||||
|  | ||||
| 	const remoteNotesCount = await Note.count({ | ||||
| 		'_user.host': { $ne: null } | ||||
| 	}); | ||||
|  | ||||
| 	const localDriveFilesCount = await DriveFile.count({ | ||||
| 		'metadata._user.host': null | ||||
| 	}); | ||||
|  | ||||
| 	const remoteDriveFilesCount = await DriveFile.count({ | ||||
| 		'metadata._user.host': { $ne: null } | ||||
| 	}); | ||||
|  | ||||
| 	const localDriveFilesSize = await DriveFile | ||||
| 		.aggregate([{ | ||||
| 			$match: { | ||||
| 				'metadata._user.host': null, | ||||
| 				'metadata.deletedAt': { $exists: false } | ||||
| 			} | ||||
| 		}, { | ||||
| 			$project: { | ||||
| 				length: true | ||||
| 			} | ||||
| 		}, { | ||||
| 			$group: { | ||||
| 				_id: null, | ||||
| 				usage: { $sum: '$length' } | ||||
| 			} | ||||
| 		}]) | ||||
| 		.then(aggregates => { | ||||
| 			if (aggregates.length > 0) { | ||||
| 				return aggregates[0].usage; | ||||
| 			} | ||||
| 			return 0; | ||||
| 		}); | ||||
|  | ||||
| 	const remoteDriveFilesSize = await DriveFile | ||||
| 		.aggregate([{ | ||||
| 			$match: { | ||||
| 				'metadata._user.host': { $ne: null }, | ||||
| 				'metadata.deletedAt': { $exists: false } | ||||
| 			} | ||||
| 		}, { | ||||
| 			$project: { | ||||
| 				length: true | ||||
| 			} | ||||
| 		}, { | ||||
| 			$group: { | ||||
| 				_id: null, | ||||
| 				usage: { $sum: '$length' } | ||||
| 			} | ||||
| 		}]) | ||||
| 		.then(aggregates => { | ||||
| 			if (aggregates.length > 0) { | ||||
| 				return aggregates[0].usage; | ||||
| 			} | ||||
| 			return 0; | ||||
| 		}); | ||||
|  | ||||
| 	await Stats.insert({ | ||||
| 		date: date, | ||||
| 		span: 'hour', | ||||
| 		users: { | ||||
| 			local: { | ||||
| 				total: localUsersCount, | ||||
| 				diff: 0 | ||||
| 			}, | ||||
| 			remote: { | ||||
| 				total: remoteUsersCount, | ||||
| 				diff: 0 | ||||
| 			} | ||||
| 		}, | ||||
| 		notes: { | ||||
| 			local: { | ||||
| 				total: localNotesCount, | ||||
| 				diff: 0, | ||||
| 				diffs: { | ||||
| 					normal: 0, | ||||
| 					reply: 0, | ||||
| 					renote: 0 | ||||
| 				} | ||||
| 			}, | ||||
| 			remote: { | ||||
| 				total: remoteNotesCount, | ||||
| 				diff: 0, | ||||
| 				diffs: { | ||||
| 					normal: 0, | ||||
| 					reply: 0, | ||||
| 					renote: 0 | ||||
| 				} | ||||
| 			} | ||||
| 		}, | ||||
| 		drive: { | ||||
| 			local: { | ||||
| 				totalCount: localDriveFilesCount, | ||||
| 				totalSize: localDriveFilesSize, | ||||
| 				diffCount: 0, | ||||
| 				diffSize: 0 | ||||
| 			}, | ||||
| 			remote: { | ||||
| 				totalCount: remoteDriveFilesCount, | ||||
| 				totalSize: remoteDriveFilesSize, | ||||
| 				diffCount: 0, | ||||
| 				diffSize: 0 | ||||
| 			} | ||||
| 		} | ||||
| 	}); | ||||
|  | ||||
| 	console.log('done'); | ||||
| } | ||||
|  | ||||
| main(); | ||||
| @@ -1,4 +1,3 @@ | ||||
| files: | ||||
|   - source: /locales/ja-JP.yml | ||||
|     translation: /locales/%locale%.yml | ||||
|     update_option: update_as_unapproved | ||||
|   | ||||
| @@ -1,12 +0,0 @@ | ||||
| import { defineConfig } from 'cypress' | ||||
|  | ||||
| export default defineConfig({ | ||||
|   e2e: { | ||||
|     // We've imported your old cypress plugins here. | ||||
|     // You may want to clean this up later by importing these. | ||||
|     setupNodeEvents(on, config) { | ||||
|       return require('./cypress/plugins/index.js')(on, config) | ||||
|     }, | ||||
|     baseUrl: 'http://localhost:61812', | ||||
|   }, | ||||
| }) | ||||
| @@ -1,149 +0,0 @@ | ||||
| describe('Before setup instance', () => { | ||||
| 	beforeEach(() => { | ||||
| 		cy.resetState(); | ||||
| 	}); | ||||
|  | ||||
| 	afterEach(() => { | ||||
| 		// テスト終了直前にページ遷移するようなテストケース(例えばアカウント作成)だと、たぶんCypressのバグでブラウザの内容が次のテストケースに引き継がれてしまう(例えばアカウントが作成し終わった段階からテストが始まる)。 | ||||
| 		// waitを入れることでそれを防止できる | ||||
| 		cy.wait(1000); | ||||
| 	}); | ||||
|  | ||||
|   it('successfully loads', () => { | ||||
|     cy.visit('/'); | ||||
|   }); | ||||
|  | ||||
| 	it('setup instance', () => { | ||||
|     cy.visit('/'); | ||||
|  | ||||
| 		cy.intercept('POST', '/api/admin/accounts/create').as('signup'); | ||||
| 	 | ||||
| 		cy.get('[data-cy-admin-username] input').type('admin'); | ||||
| 		cy.get('[data-cy-admin-password] input').type('admin1234'); | ||||
| 		cy.get('[data-cy-admin-ok]').click(); | ||||
|  | ||||
| 		// なぜか動かない | ||||
| 		//cy.wait('@signup').should('have.property', 'response.statusCode'); | ||||
| 		cy.wait('@signup'); | ||||
|   }); | ||||
| }); | ||||
|  | ||||
| describe('After setup instance', () => { | ||||
| 	beforeEach(() => { | ||||
| 		cy.resetState(); | ||||
|  | ||||
| 		// インスタンス初期セットアップ | ||||
| 		cy.registerUser('admin', 'pass', true); | ||||
| 	}); | ||||
|  | ||||
| 	afterEach(() => { | ||||
| 		// テスト終了直前にページ遷移するようなテストケース(例えばアカウント作成)だと、たぶんCypressのバグでブラウザの内容が次のテストケースに引き継がれてしまう(例えばアカウントが作成し終わった段階からテストが始まる)。 | ||||
| 		// waitを入れることでそれを防止できる | ||||
| 		cy.wait(1000); | ||||
| 	}); | ||||
|  | ||||
|   it('successfully loads', () => { | ||||
|     cy.visit('/'); | ||||
|   }); | ||||
|  | ||||
| 	it('signup', () => { | ||||
| 		cy.visit('/'); | ||||
|  | ||||
| 		cy.intercept('POST', '/api/signup').as('signup'); | ||||
|  | ||||
| 		cy.get('[data-cy-signup]').click(); | ||||
| 		cy.get('[data-cy-signup-username] input').type('alice'); | ||||
| 		cy.get('[data-cy-signup-password] input').type('alice1234'); | ||||
| 		cy.get('[data-cy-signup-password-retype] input').type('alice1234'); | ||||
| 		cy.get('[data-cy-signup-submit]').click(); | ||||
|  | ||||
| 		cy.wait('@signup'); | ||||
|   }); | ||||
| }); | ||||
|  | ||||
| describe('After user signup', () => { | ||||
| 	beforeEach(() => { | ||||
| 		cy.resetState(); | ||||
|  | ||||
| 		// インスタンス初期セットアップ | ||||
| 		cy.registerUser('admin', 'pass', true); | ||||
|  | ||||
| 		// ユーザー作成 | ||||
| 		cy.registerUser('alice', 'alice1234'); | ||||
| 	}); | ||||
|  | ||||
| 	afterEach(() => { | ||||
| 		// テスト終了直前にページ遷移するようなテストケース(例えばアカウント作成)だと、たぶんCypressのバグでブラウザの内容が次のテストケースに引き継がれてしまう(例えばアカウントが作成し終わった段階からテストが始まる)。 | ||||
| 		// waitを入れることでそれを防止できる | ||||
| 		cy.wait(1000); | ||||
| 	}); | ||||
|  | ||||
|   it('successfully loads', () => { | ||||
|     cy.visit('/'); | ||||
|   }); | ||||
|  | ||||
| 	it('signin', () => { | ||||
| 		cy.visit('/'); | ||||
|  | ||||
| 		cy.intercept('POST', '/api/signin').as('signin'); | ||||
|  | ||||
| 		cy.get('[data-cy-signin]').click(); | ||||
| 		cy.get('[data-cy-signin-username] input').type('alice'); | ||||
| 		// Enterキーでサインインできるかの確認も兼ねる | ||||
| 		cy.get('[data-cy-signin-password] input').type('alice1234{enter}'); | ||||
|  | ||||
| 		cy.wait('@signin'); | ||||
|   }); | ||||
|  | ||||
| 	it('suspend', function() { | ||||
| 		cy.request('POST', '/api/admin/suspend-user', { | ||||
| 			i: this.admin.token, | ||||
| 			userId: this.alice.id, | ||||
| 		}); | ||||
|  | ||||
| 		cy.visit('/'); | ||||
|  | ||||
| 		cy.get('[data-cy-signin]').click(); | ||||
| 		cy.get('[data-cy-signin-username] input').type('alice'); | ||||
| 		cy.get('[data-cy-signin-password] input').type('alice1234{enter}'); | ||||
|  | ||||
| 		// TODO: cypressにブラウザの言語指定できる機能が実装され次第英語のみテストするようにする | ||||
| 		cy.contains(/アカウントが凍結されています|This account has been suspended due to/gi); | ||||
| 	}); | ||||
| }); | ||||
|  | ||||
| describe('After user singed in', () => { | ||||
| 	beforeEach(() => { | ||||
| 		cy.resetState(); | ||||
|  | ||||
| 		// インスタンス初期セットアップ | ||||
| 		cy.registerUser('admin', 'pass', true); | ||||
|  | ||||
| 		// ユーザー作成 | ||||
| 		cy.registerUser('alice', 'alice1234'); | ||||
|  | ||||
| 		cy.login('alice', 'alice1234'); | ||||
| 	}); | ||||
|  | ||||
| 	afterEach(() => { | ||||
| 		// テスト終了直前にページ遷移するようなテストケース(例えばアカウント作成)だと、たぶんCypressのバグでブラウザの内容が次のテストケースに引き継がれてしまう(例えばアカウントが作成し終わった段階からテストが始まる)。 | ||||
| 		// waitを入れることでそれを防止できる | ||||
| 		cy.wait(1000); | ||||
| 	}); | ||||
|  | ||||
|   it('successfully loads', () => { | ||||
| 		cy.get('[data-cy-open-post-form]').should('be.visible'); | ||||
|   }); | ||||
|  | ||||
| 	it('note', () => { | ||||
| 		cy.get('[data-cy-open-post-form]').click(); | ||||
| 		cy.get('[data-cy-post-form-text]').type('Hello, Misskey!'); | ||||
| 		cy.get('[data-cy-open-post-form-submit]').click(); | ||||
|  | ||||
| 		cy.contains('Hello, Misskey!'); | ||||
|   }); | ||||
| }); | ||||
|  | ||||
| // TODO: 投稿フォームの公開範囲指定のテスト | ||||
| // TODO: 投稿フォームのファイル添付のテスト | ||||
| // TODO: 投稿フォームのハッシュタグ保持フィールドのテスト | ||||
| @@ -1,65 +0,0 @@ | ||||
| describe('After user signed in', () => { | ||||
| 	beforeEach(() => { | ||||
| 		cy.resetState(); | ||||
| 		cy.viewport('macbook-16'); | ||||
|  | ||||
| 		// インスタンス初期セットアップ | ||||
| 		cy.registerUser('admin', 'pass', true); | ||||
|  | ||||
| 		// ユーザー作成 | ||||
| 		cy.registerUser('alice', 'alice1234'); | ||||
|  | ||||
| 		cy.login('alice', 'alice1234'); | ||||
| 	}); | ||||
|  | ||||
| 	afterEach(() => { | ||||
| 		// テスト終了直前にページ遷移するようなテストケース(例えばアカウント作成)だと、たぶんCypressのバグでブラウザの内容が次のテストケースに引き継がれてしまう(例えばアカウントが作成し終わった段階からテストが始まる)。 | ||||
| 		// waitを入れることでそれを防止できる | ||||
| 		cy.wait(1000); | ||||
| 	}); | ||||
|  | ||||
|   it('widget edit toggle is visible', () => { | ||||
| 		cy.get('.mk-widget-edit').should('be.visible'); | ||||
|   }); | ||||
|  | ||||
| 	it('widget select should be visible in edit mode', () => { | ||||
| 		cy.get('.mk-widget-edit').click(); | ||||
| 		cy.get('.mk-widget-select').should('be.visible'); | ||||
|   }); | ||||
|  | ||||
| 	it('first widget should be removed', () => { | ||||
| 		cy.get('.mk-widget-edit').click(); | ||||
| 		cy.get('.customize-container:first-child .remove._button').click(); | ||||
| 		cy.get('.customize-container').should('have.length', 2); | ||||
| 	}); | ||||
|  | ||||
| 	function buildWidgetTest(widgetName) { | ||||
| 		it(`${widgetName} widget should get added`, () => { | ||||
| 			cy.get('.mk-widget-edit').click(); | ||||
| 			cy.get('.mk-widget-select select').select(widgetName, { force: true }); | ||||
| 			cy.get('.bg._modalBg.transparent').click({ multiple: true, force: true }); | ||||
| 			cy.get('.mk-widget-add').click({ force: true }); | ||||
| 			cy.get(`.mkw-${widgetName}`).should('exist'); | ||||
| 		}); | ||||
| 	} | ||||
|  | ||||
| 	buildWidgetTest('memo'); | ||||
| 	buildWidgetTest('notifications'); | ||||
| 	buildWidgetTest('timeline'); | ||||
| 	buildWidgetTest('calendar'); | ||||
| 	buildWidgetTest('rss'); | ||||
| 	buildWidgetTest('trends'); | ||||
| 	buildWidgetTest('clock'); | ||||
| 	buildWidgetTest('activity'); | ||||
| 	buildWidgetTest('photos'); | ||||
| 	buildWidgetTest('digitalClock'); | ||||
| 	buildWidgetTest('federation'); | ||||
| 	buildWidgetTest('postForm'); | ||||
| 	buildWidgetTest('slideshow'); | ||||
| 	buildWidgetTest('serverMetric'); | ||||
| 	buildWidgetTest('onlineUsers'); | ||||
| 	buildWidgetTest('jobQueue'); | ||||
| 	buildWidgetTest('button'); | ||||
| 	buildWidgetTest('aiscript'); | ||||
| 	buildWidgetTest('aichan'); | ||||
| }); | ||||
| @@ -1,5 +0,0 @@ | ||||
| { | ||||
|   "name": "Using fixtures to represent data", | ||||
|   "email": "hello@cypress.io", | ||||
|   "body": "Fixtures are a great way to mock data for responses to routes" | ||||
| } | ||||
| @@ -1,22 +0,0 @@ | ||||
| /// <reference types="cypress" /> | ||||
| // *********************************************************** | ||||
| // This example plugins/index.js can be used to load plugins | ||||
| // | ||||
| // You can change the location of this file or turn off loading | ||||
| // the plugins file with the 'pluginsFile' configuration option. | ||||
| // | ||||
| // You can read more here: | ||||
| // https://on.cypress.io/plugins-guide | ||||
| // *********************************************************** | ||||
|  | ||||
| // This function is called when a project is opened or re-opened (e.g. due to | ||||
| // the project's config changing) | ||||
|  | ||||
| /** | ||||
|  * @type {Cypress.PluginConfig} | ||||
|  */ | ||||
| // eslint-disable-next-line no-unused-vars | ||||
| module.exports = (on, config) => { | ||||
|   // `on` is used to hook into various events Cypress emits | ||||
|   // `config` is the resolved Cypress config | ||||
| } | ||||
| @@ -1,55 +0,0 @@ | ||||
| // *********************************************** | ||||
| // This example commands.js shows you how to | ||||
| // create various custom commands and overwrite | ||||
| // existing commands. | ||||
| // | ||||
| // For more comprehensive examples of custom | ||||
| // commands please read more here: | ||||
| // https://on.cypress.io/custom-commands | ||||
| // *********************************************** | ||||
| // | ||||
| // | ||||
| // -- This is a parent command -- | ||||
| // Cypress.Commands.add('login', (email, password) => { ... }) | ||||
| // | ||||
| // | ||||
| // -- This is a child command -- | ||||
| // Cypress.Commands.add('drag', { prevSubject: 'element'}, (subject, options) => { ... }) | ||||
| // | ||||
| // | ||||
| // -- This is a dual command -- | ||||
| // Cypress.Commands.add('dismiss', { prevSubject: 'optional'}, (subject, options) => { ... }) | ||||
| // | ||||
| // | ||||
| // -- This will overwrite an existing command -- | ||||
| // Cypress.Commands.overwrite('visit', (originalFn, url, options) => { ... }) | ||||
|  | ||||
| Cypress.Commands.add('resetState', () => { | ||||
| 	cy.window(win => { | ||||
| 		win.indexedDB.deleteDatabase('keyval-store'); | ||||
| 	}); | ||||
| 	cy.request('POST', '/api/reset-db').as('reset'); | ||||
| 	cy.get('@reset').its('status').should('equal', 204); | ||||
| 	cy.reload(true); | ||||
| }); | ||||
|  | ||||
| Cypress.Commands.add('registerUser', (username, password, isAdmin = false) => { | ||||
| 	const route = isAdmin ? '/api/admin/accounts/create' : '/api/signup'; | ||||
|  | ||||
| 	cy.request('POST', route, { | ||||
| 		username: username, | ||||
| 		password: password, | ||||
| 	}).its('body').as(username); | ||||
| }); | ||||
|  | ||||
| Cypress.Commands.add('login', (username, password) => { | ||||
| 	cy.visit('/'); | ||||
|  | ||||
| 	cy.intercept('POST', '/api/signin').as('signin'); | ||||
|  | ||||
| 	cy.get('[data-cy-signin]').click(); | ||||
| 	cy.get('[data-cy-signin-username] input').type(username); | ||||
| 	cy.get('[data-cy-signin-password] input').type(`${password}{enter}`); | ||||
|  | ||||
| 	cy.wait('@signin').as('signedIn'); | ||||
| }); | ||||
| @@ -1,32 +0,0 @@ | ||||
| // *********************************************************** | ||||
| // This example support/index.js is processed and | ||||
| // loaded automatically before your test files. | ||||
| // | ||||
| // This is a great place to put global configuration and | ||||
| // behavior that modifies Cypress. | ||||
| // | ||||
| // You can change the location of this file or turn off | ||||
| // automatically serving support files with the | ||||
| // 'supportFile' configuration option. | ||||
| // | ||||
| // You can read more here: | ||||
| // https://on.cypress.io/configuration | ||||
| // *********************************************************** | ||||
|  | ||||
| // Import commands.js using ES2015 syntax: | ||||
| import './commands' | ||||
|  | ||||
| // Alternatively you can use CommonJS syntax: | ||||
| // require('./commands') | ||||
|  | ||||
| Cypress.on('uncaught:exception', (err, runnable) => { | ||||
| 	if ([ | ||||
| 		// Chrome | ||||
| 		'ResizeObserver loop limit exceeded', | ||||
|  | ||||
| 		// Firefox | ||||
| 		'ResizeObserver loop completed with undelivered notifications', | ||||
| 	].some(msg => err.message.includes(msg))) { | ||||
| 		return false; | ||||
| 	} | ||||
| }); | ||||
| @@ -5,46 +5,46 @@ services: | ||||
|     build: . | ||||
|     restart: always | ||||
|     links: | ||||
|       - db | ||||
|       - redis | ||||
|       - mongo | ||||
| #      - redis | ||||
| #      - es | ||||
|     ports: | ||||
|       - "3000:3000" | ||||
|       - "127.0.0.1:3000:3000" | ||||
|     networks: | ||||
|       - internal_network | ||||
|       - external_network | ||||
|     volumes: | ||||
|       - ./files:/misskey/files | ||||
|       - ./.config:/misskey/.config:ro | ||||
|  | ||||
|   redis: | ||||
| #  redis: | ||||
| #    restart: always | ||||
| #    image: redis:4.0-alpine | ||||
| #    networks: | ||||
| #      - internal_network | ||||
| ### Uncomment to enable Redis persistance | ||||
| ##    volumes: | ||||
| ##      - ./redis:/data | ||||
|  | ||||
|   mongo: | ||||
|     restart: always | ||||
|     image: redis:4.0-alpine | ||||
|     image: mongo:4.1 | ||||
|     networks: | ||||
|       - internal_network | ||||
|     environment: | ||||
|       MONGO_INITDB_DATABASE: "misskey" | ||||
|     volumes: | ||||
|       - ./redis:/data | ||||
|  | ||||
|   db: | ||||
|     restart: always | ||||
|     image: postgres:12.2-alpine | ||||
|     networks: | ||||
|       - internal_network | ||||
|     env_file: | ||||
|       - .config/docker.env | ||||
|     volumes: | ||||
|       - ./db:/var/lib/postgresql/data | ||||
|       - ./.config/mongo_initdb.js:/docker-entrypoint-initdb.d/mongo_initdb.js:ro | ||||
| ### Uncomment to enable MongoDB persistance | ||||
| #      - ./mongo:/data | ||||
|  | ||||
| #  es: | ||||
| #    restart: always | ||||
| #    image: docker.elastic.co/elasticsearch/elasticsearch-oss:6.4.2 | ||||
| #    environment: | ||||
| #      - "ES_JAVA_OPTS=-Xms512m -Xmx512m" | ||||
| #      - "TAKE_FILE_OWNERSHIP=111" | ||||
| #    networks: | ||||
| #      - internal_network | ||||
| #    volumes: | ||||
| #      - ./elasticsearch:/usr/share/elasticsearch/data | ||||
| #### Uncomment to enable ES persistence | ||||
| ##    volumes: | ||||
| ##      - ./elasticsearch:/usr/share/elasticsearch/data | ||||
|  | ||||
| networks: | ||||
|   internal_network: | ||||
|   | ||||
							
								
								
									
										6
									
								
								docs/README.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,6 @@ | ||||
| # Docs | ||||
| These docs are for contributors of Misskey or admins of instance of Misskey. | ||||
| Docs for users are located in `src/docs`. | ||||
|  | ||||
| これらのドキュメントはMisskeyの開発者またはMisskeyインスタンス運営者向けです。 | ||||
| 利用者向けのドキュメントは`src/docs`にあります。 | ||||
							
								
								
									
										22
									
								
								docs/backup.fr.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,22 @@ | ||||
| Comment faire une sauvegarde de votre Misskey ? | ||||
| ========================== | ||||
|  | ||||
| Assurez-vous d'avoir installé **mongodb-tools**. | ||||
|  | ||||
| --- | ||||
|  | ||||
| Dans votre terminal : | ||||
| ``` shell | ||||
| $ mongodump --archive=db-backup -u <VotreNomdUtilisateur> -p <VotreMotDePasse> | ||||
| ``` | ||||
|  | ||||
| Pour plus de détails, merci de consulter [la documentation de mongodump](https://docs.mongodb.com/manual/reference/program/mongodump/). | ||||
|  | ||||
| Restauration | ||||
| ------- | ||||
|  | ||||
| ``` shell | ||||
| $ mongorestore --archive=db-backup | ||||
| ``` | ||||
|  | ||||
| Pour plus de détails, merci de consulter [la documentation de mongorestore](https://docs.mongodb.com/manual/reference/program/mongorestore/). | ||||
							
								
								
									
										22
									
								
								docs/backup.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,22 @@ | ||||
| How to backup your Misskey | ||||
| ========================== | ||||
|  | ||||
| Make sure **mongodb-tools** installed. | ||||
|  | ||||
| --- | ||||
|  | ||||
| In your shell: | ||||
| ``` shell | ||||
| $ mongodump --archive=db-backup -u <YourUserName> -p <YourPassword> | ||||
| ``` | ||||
|  | ||||
| For details, please see [mongodump docs](https://docs.mongodb.com/manual/reference/program/mongodump/). | ||||
|  | ||||
| Restore | ||||
| ------- | ||||
|  | ||||
| ``` shell | ||||
| $ mongorestore --archive=db-backup | ||||
| ``` | ||||
|  | ||||
| For details, please see [mongorestore docs](https://docs.mongodb.com/manual/reference/program/mongorestore/). | ||||
							
								
								
									
										75
									
								
								docs/docker.en.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,75 @@ | ||||
| Docker Guide | ||||
| ================================================================ | ||||
|  | ||||
| This guide describes how to install and setup Misskey with Docker. | ||||
|  | ||||
| [Japanese version also available - 日本語版もあります](./docker.ja.md) | ||||
|  | ||||
| ---------------------------------------------------------------- | ||||
|  | ||||
| *1.* Download Misskey | ||||
| ---------------------------------------------------------------- | ||||
| 1. Clone Misskey repository's master branch. | ||||
|  | ||||
| 	`git clone -b master git://github.com/syuilo/misskey.git` | ||||
|  | ||||
| 2. Move to misskey directory. | ||||
|  | ||||
| 	`cd misskey` | ||||
|  | ||||
| 3. Checkout to the [latest release](https://github.com/syuilo/misskey/releases/latest) tag. | ||||
|  | ||||
| 	```bash | ||||
| 	git tag | grep '^10\.' | sort -V --reverse | \ | ||||
| 	while read tag_name; do \ | ||||
| 	if ! curl -s "https://api.github.com/repos/syuilo/misskey/releases/tags/$tag_name" \ | ||||
| 	| grep -qE '"(draft|prerelease)": true'; \ | ||||
| 	then git checkout $tag_name; break; fi ; done | ||||
| 	``` | ||||
|  | ||||
| *2.* Configure Misskey | ||||
| ---------------------------------------------------------------- | ||||
| 1. `cp .config/example.yml .config/default.yml` Copy the `.config/example.yml` and rename it to `default.yml`. | ||||
| 2. `cp .config/mongo_initdb_example.js .config/mongo_initdb.js` Copy the `.config/mongo_initdb_example.js` and rename it to `mongo_initdb.js`. | ||||
| 3. Edit `default.yml` and `mongo_initdb.js`. | ||||
|  | ||||
| *3.* Configure Docker | ||||
| ---------------------------------------------------------------- | ||||
| Edit `docker-compose.yml`. | ||||
|  | ||||
| *4.* Build Misskey | ||||
| ---------------------------------------------------------------- | ||||
| Build misskey with the following: | ||||
|  | ||||
| `docker-compose build` | ||||
|  | ||||
| *5.* That is it. | ||||
| ---------------------------------------------------------------- | ||||
| Well done! Now you have an environment to run Misskey. | ||||
|  | ||||
| ### Launch normally | ||||
| Just `docker-compose up -d`. GLHF! | ||||
|  | ||||
| ### How to update your Misskey server to the latest version | ||||
| 1. `git fetch` | ||||
| 2. `git stash` | ||||
| 3.  | ||||
|  | ||||
| 	```bash | ||||
| 	git tag | grep '^10\.' | sort -V --reverse | \ | ||||
| 	while read tag_name; do \ | ||||
| 	if ! curl -s "https://api.github.com/repos/syuilo/misskey/releases/tags/$tag_name" \ | ||||
| 	| grep -qE '"(draft|prerelease)": true'; \ | ||||
| 	then git checkout $tag_name; break; fi ; done | ||||
| 	``` | ||||
| 4. `git stash pop` | ||||
| 5. `docker-compose build` | ||||
| 6. Check [ChangeLog](../CHANGELOG.md) for migration information | ||||
| 7. `docker-compose stop && docker-compose up -d` | ||||
|  | ||||
| ### How to execute [cli commands](manage.en.md): | ||||
| `docker-compose run --rm web node cli/mark-admin @example` | ||||
|  | ||||
| ---------------------------------------------------------------- | ||||
|  | ||||
| If you have any questions or trouble, feel free to contact us! | ||||
							
								
								
									
										103
									
								
								docs/docker.fr.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,103 @@ | ||||
| Guide Docker | ||||
| ================================================================ | ||||
|  | ||||
| Ce guide explique comment installer et configurer Misskey avec Docker. | ||||
|  | ||||
| [Version japonaise également disponible - Japanese version also available - 日本語版もあります](./docker.ja.md)   | ||||
| [Version anglaise également disponible - English version also available - 英語版もあります](./docker.en.md) | ||||
|  | ||||
| ---------------------------------------------------------------- | ||||
|  | ||||
| *1.* Télécharger Misskey | ||||
| ---------------------------------------------------------------- | ||||
| 1. Clone le dépôt de Misskey sur la branche master. | ||||
|  | ||||
| 	`git clone -b master git://github.com/syuilo/misskey.git` | ||||
|  | ||||
| 2. Naviguez dans le dossier du dépôt. | ||||
|  | ||||
| 	`cd misskey` | ||||
|  | ||||
| 3. Checkout sur le tag de la [dernière version](https://github.com/syuilo/misskey/releases/latest). | ||||
|  | ||||
| 	```bash | ||||
| 	git tag | grep '^10\.' | sort -V --reverse | \ | ||||
| 	while read tag_name; do \ | ||||
| 	if ! curl -s "https://api.github.com/repos/syuilo/misskey/releases/tags/$tag_name" \ | ||||
| 	| grep -qE '"(draft|prerelease)": true'; \ | ||||
| 	then git checkout $tag_name; break; fi ; done | ||||
| 	``` | ||||
|  | ||||
| *2.* Configuration de Misskey | ||||
| ---------------------------------------------------------------- | ||||
| 1. `cp .config/example.yml .config/default.yml` Copiez le fichier `.config/example.yml` et renommez-le `default.yml`. | ||||
| 2. `cp .config/mongo_initdb_example.js .config/mongo_initdb.js` Copie le fichier `.config/mongo_initdb_example.js` et le renomme en `mongo_initdb.js`. | ||||
| 3. Editez `default.yml` et `mongo_initdb.js`. | ||||
|  | ||||
| *3.* Configurer Docker | ||||
| ---------------------------------------------------------------- | ||||
| Editez `docker-compose.yml`. | ||||
|  | ||||
| *4.* Contruire Misskey | ||||
| ---------------------------------------------------------------- | ||||
| Contruire l'image Docker avec: | ||||
|  | ||||
| `docker-compose build` | ||||
|  | ||||
| *5.* C'est tout ! | ||||
| ---------------------------------------------------------------- | ||||
| Parfait, Vous avez un environnement prêt pour démarrer Misskey. | ||||
|  | ||||
| ### Lancer normalement | ||||
| Utilisez la commande `docker-compose up -d`. GLHF! | ||||
|  | ||||
| ### How to update your Misskey server to the latest version | ||||
| 1. `git fetch` | ||||
| 2. `git stash` | ||||
| 3.  | ||||
|  | ||||
| 	```bash | ||||
| 	git tag | grep '^10\.' | sort -V --reverse | \ | ||||
| 	while read tag_name; do \ | ||||
| 	if ! curl -s "https://api.github.com/repos/syuilo/misskey/releases/tags/$tag_name" \ | ||||
| 	| grep -qE '"(draft|prerelease)": true'; \ | ||||
| 	then git checkout $tag_name; break; fi ; done | ||||
| 	``` | ||||
| 4. `git stash pop` | ||||
| 5. `docker-compose build` | ||||
| 6. Consultez le [ChangeLog](../CHANGELOG.md) pour avoir les éventuelles informations de migration | ||||
| 7. `docker-compose stop && docker-compose up -d` | ||||
|  | ||||
| ### Comment exécuter des [commandes](manage.fr.md) | ||||
| `docker-compose run --rm web node cli/mark-admin @example` | ||||
|  | ||||
| ### Configuration d'ElasticSearch (pour la fonction de recherche) | ||||
| *1.* Préparation de l'environnement | ||||
| ---------------------------------------------------------------- | ||||
| 1. Permet de créer le dossier d'accueil de la base ElasticSearch aves les bons droits | ||||
|  | ||||
| 	`mkdir elasticsearch && chown 1000:1000 elasticsearch` | ||||
|  | ||||
| 2. Augmente la valeur max du paramètre map_count du système (valeur minimum pour pouvoir lancer ES) | ||||
|  | ||||
| 	`sysctl -w vm.max_map_count=262144` | ||||
|  | ||||
| *2.* Après lancement du docker-compose, initialisation de la base ElasticSearch | ||||
| ---------------------------------------------------------------- | ||||
| 1. Connexion dans le conteneur web | ||||
|  | ||||
| 	`docker-compose -it web /bin/sh` | ||||
|  | ||||
| 2. Ajout du paquet curl | ||||
|  | ||||
| 	`apk add curl` | ||||
|  | ||||
| 3. Création de la base ES | ||||
|  | ||||
| 	`curl -X PUT "es:9200/misskey" -H 'Content-Type: application/json' -d'{ "settings" : { "index" : { } }}'` | ||||
|  | ||||
| 4. `exit` | ||||
|  | ||||
| ---------------------------------------------------------------- | ||||
|  | ||||
| Si vous avez des questions ou des problèmes, n'hésitez pas à nous contacter ! | ||||
							
								
								
									
										76
									
								
								docs/docker.ja.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,76 @@ | ||||
| Dockerを使ったMisskey構築方法 | ||||
| ================================================================ | ||||
|  | ||||
| このガイドはDockerを使ったMisskeyセットアップ方法について解説します。 | ||||
|  | ||||
| [英語版もあります - English version also available](./docker.en.md) | ||||
|  | ||||
| ---------------------------------------------------------------- | ||||
|  | ||||
| *1.* Misskeyのダウンロード | ||||
| ---------------------------------------------------------------- | ||||
| 1. masterブランチからMisskeyレポジトリをクローン | ||||
|  | ||||
| 	`git clone -b master git://github.com/syuilo/misskey.git` | ||||
|  | ||||
| 2. misskeyディレクトリに移動 | ||||
|  | ||||
| 	`cd misskey` | ||||
|  | ||||
| 3. [最新のリリース](https://github.com/syuilo/misskey/releases/latest)を確認 | ||||
|  | ||||
| 	```bash | ||||
| 	git tag | grep '^10\.' | sort -V --reverse | \ | ||||
| 	while read tag_name; do \ | ||||
| 	if ! curl -s "https://api.github.com/repos/syuilo/misskey/releases/tags/$tag_name" \ | ||||
| 	| grep -qE '"(draft|prerelease)": true'; \ | ||||
| 	then git checkout $tag_name; break; fi ; done | ||||
| 	``` | ||||
|  | ||||
| *2.* 設定ファイルを作成する | ||||
| ---------------------------------------------------------------- | ||||
| 1. `cp .config/example.yml .config/default.yml` `.config/example.yml`をコピーし名前を`default.yml`にする | ||||
| 2. `cp .config/mongo_initdb_example.js .config/mongo_initdb.js` `.config/mongo_initdb_example.js`をコピーし名前を`mongo_initdb.js`にする | ||||
| 3. `default.yml`と`mongo_initdb.js`を編集する | ||||
|  | ||||
| *3.* Dockerの設定 | ||||
| ---------------------------------------------------------------- | ||||
| `docker-compose.yml`を編集してください。 | ||||
|  | ||||
| *4.* Misskeyのビルド | ||||
| ---------------------------------------------------------------- | ||||
| 次のコマンドでMisskeyをビルドしてください: | ||||
|  | ||||
| `docker-compose build` | ||||
|  | ||||
| *5.* 以上です! | ||||
| ---------------------------------------------------------------- | ||||
| お疲れ様でした。これでMisskeyを動かす準備は整いました。 | ||||
|  | ||||
| ### 通常起動 | ||||
| `docker-compose up -d`するだけです。GLHF! | ||||
|  | ||||
| ### Misskeyを最新バージョンにアップデートする方法: | ||||
| 1. `git fetch` | ||||
| 2. `git stash` | ||||
| 3.  | ||||
|  | ||||
| 	```bash | ||||
| 	git tag | grep '^10\.' | sort -V --reverse | \ | ||||
| 	while read tag_name; do \ | ||||
| 	if ! curl -s "https://api.github.com/repos/syuilo/misskey/releases/tags/$tag_name" \ | ||||
| 	| grep -qE '"(draft|prerelease)": true'; \ | ||||
| 	then git checkout $tag_name; break; fi ; done | ||||
| 	``` | ||||
| 4. `git stash pop` | ||||
| 5. `docker-compose build` | ||||
| 6. [ChangeLog](../CHANGELOG.md)でマイグレーション情報を確認する | ||||
| 7. `docker-compose stop && docker-compose up -d` | ||||
|  | ||||
| ### cliコマンドを実行する方法: | ||||
|  | ||||
| `docker-compose run --rm web node cli/mark-admin @example` | ||||
|  | ||||
| ---------------------------------------------------------------- | ||||
|  | ||||
| なにかお困りのことがありましたらお気軽にご連絡ください。 | ||||
							
								
								
									
										70
									
								
								docs/examples/misskey.nginx
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,70 @@ | ||||
| # Sample nginx configuration for Misskey | ||||
| # | ||||
| # 1. Replace example.tld to your domain | ||||
| # 2. Copy to /etc/nginx/sites-available/ and then symlink from /etc/nginx/sites-ebabled/ | ||||
| #    or copy to /etc/nginx/conf.d/ | ||||
|  | ||||
| # For WebSocket | ||||
| map $http_upgrade $connection_upgrade { | ||||
|     default upgrade; | ||||
|     ''      close; | ||||
| } | ||||
|  | ||||
| proxy_cache_path /tmp/nginx_cache levels=1:2 keys_zone=cache1:16m max_size=1g inactive=720m use_temp_path=off; | ||||
|  | ||||
| server { | ||||
|     listen 80; | ||||
|     listen [::]:80; | ||||
|     server_name example.tld; | ||||
|  | ||||
|     # For SSL domain validation | ||||
|     root /var/www/html; | ||||
|     location /.well-known/acme-challenge/ { allow all; } | ||||
|     location /.well-known/pki-validation/ { allow all; } | ||||
|     location / { return 301 https://$server_name$request_uri; } | ||||
| } | ||||
|  | ||||
| server { | ||||
|     listen 443 http2; | ||||
|     listen [::]:443 http2; | ||||
|     server_name example.tld; | ||||
|     ssl on; | ||||
| 		ssl_session_cache shared:ssl_session_cache:10m; | ||||
|  | ||||
|     # To use Let's Encrypt certificate | ||||
|     ssl_certificate     /etc/letsencrypt/live/example.tld/fullchain.pem; | ||||
|     ssl_certificate_key /etc/letsencrypt/live/example.tld/privkey.pem; | ||||
|  | ||||
|     # To use Debian/Ubuntu's self-signed certificate (For testing or before issuing a certificate) | ||||
|     #ssl_certificate     /etc/ssl/certs/ssl-cert-snakeoil.pem; | ||||
|     #ssl_certificate_key /etc/ssl/private/ssl-cert-snakeoil.key; | ||||
|  | ||||
|     # SSL protocol settings | ||||
|     ssl_protocols TLSv1 TLSv1.2; | ||||
|     ssl_ciphers ECDHE-RSA-AES256-GCM-SHA384:ECDHE-RSA-AES128-GCM-SHA256:ECDHE-RSA-AES256-SHA384:ECDHE-RSA-AES128-SHA256:ECDHE-RSA-AES256-SHA:ECDHE-RSA-AES128-SHA:AES128-SHA; | ||||
|     ssl_prefer_server_ciphers on; | ||||
|  | ||||
|     # Change to your upload limit | ||||
|     client_max_body_size 80m; | ||||
|  | ||||
|     # Proxy to Node | ||||
|     location / { | ||||
|         proxy_pass http://127.0.0.1:3000; | ||||
|         proxy_set_header Host $host; | ||||
|         proxy_set_header X-Real-IP $remote_addr; | ||||
|         proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; | ||||
|         proxy_set_header X-Forwarded-Proto https; | ||||
|         proxy_http_version 1.1; | ||||
|         proxy_redirect off; | ||||
|  | ||||
|         # For WebSocket | ||||
|         proxy_set_header Upgrade $http_upgrade; | ||||
|         proxy_set_header Connection $connection_upgrade; | ||||
|  | ||||
|         # Cache settings | ||||
|         proxy_cache cache1; | ||||
|         proxy_cache_lock on; | ||||
|         proxy_cache_use_stale updating; | ||||
|         add_header X-Cache $upstream_cache_status; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										18
									
								
								docs/manage.en.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,18 @@ | ||||
| # Management guide | ||||
|  | ||||
| ## Check the status of the job queue | ||||
| coming soon | ||||
|  | ||||
| ## Mark as 'admin' user | ||||
| ``` shell | ||||
| node cli/mark-admin (User-ID or Username) | ||||
| ``` | ||||
|  | ||||
| e.g. | ||||
| ``` shell | ||||
| # By id | ||||
| node cli/mark-admin 57d01a501fdf2d07be417afe | ||||
|  | ||||
| # By username | ||||
| node cli/suspend @syuilo | ||||
| ``` | ||||
							
								
								
									
										18
									
								
								docs/manage.fr.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,18 @@ | ||||
| # Guide d'administration | ||||
|  | ||||
| ## Vérifier le status de la file d'attente des taches | ||||
| coming soon | ||||
|  | ||||
| ## Marquer un utilisateur en tant que 'admin' | ||||
| ``` shell | ||||
| node cli/mark-admin (ID utilisateur ou nom d'utilisateur) | ||||
| ``` | ||||
|  | ||||
| Exemple : | ||||
| ``` shell | ||||
| # Par id | ||||
| node cli/mark-admin 57d01a501fdf2d07be417afe | ||||
|  | ||||
| # Par nom d'utilisateur | ||||
| node cli/suspend @syuilo | ||||
| ``` | ||||
							
								
								
									
										18
									
								
								docs/manage.ja.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,18 @@ | ||||
| # 運営ガイド | ||||
|  | ||||
| ## ジョブキューの状態を調べる | ||||
| coming soon | ||||
|  | ||||
| ## 管理者ユーザーを設定する | ||||
| ``` shell | ||||
| node cli/mark-admin (ユーザーID または ユーザー名) | ||||
| ``` | ||||
|  | ||||
| 例: | ||||
| ``` shell | ||||
| # ユーザーID | ||||
| node cli/mark-admin 57d01a501fdf2d07be417afe | ||||
|  | ||||
| # ユーザー名 | ||||
| node cli/mark-admin @syuilo | ||||
| ``` | ||||
							
								
								
									
										158
									
								
								docs/setup.en.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,158 @@ | ||||
| Misskey Setup and Installation Guide | ||||
| ================================================================ | ||||
|  | ||||
| We thank you for your interest in setting up your Misskey server! | ||||
| This guide describes how to install and setup Misskey. | ||||
|  | ||||
| [Japanese version also available - 日本語版もあります](./setup.ja.md) | ||||
|  | ||||
| ---------------------------------------------------------------- | ||||
|  | ||||
| *1.* Create Misskey user | ||||
| ---------------------------------------------------------------- | ||||
| Running misskey as root is not a good idea so we create a user for that. | ||||
| In debian for exemple : | ||||
|  | ||||
| ``` | ||||
| adduser --disabled-password --disabled-login misskey | ||||
| ``` | ||||
|  | ||||
| *2.* Install dependencies | ||||
| ---------------------------------------------------------------- | ||||
| Please install and setup these softwares: | ||||
|  | ||||
| #### Dependencies :package: | ||||
| * **[Node.js](https://nodejs.org/en/)** >= 10.0.0 | ||||
| * **[MongoDB](https://www.mongodb.com/)** >= 3.6 | ||||
|  | ||||
| ##### Optional | ||||
| * [Redis](https://redis.io/) | ||||
|   * Redis is optional, but we strongly recommended to install it | ||||
| * [Elasticsearch](https://www.elastic.co/) - required to enable the search feature | ||||
| * [FFmpeg](https://www.ffmpeg.org/) | ||||
|  | ||||
| *3.* Setup MongoDB | ||||
| ---------------------------------------------------------------- | ||||
| As root: | ||||
| 1. `mongo` Go to the mongo shell | ||||
| 2. `use misskey` Use the misskey database | ||||
| 3. `db.createUser( { user: "misskey", pwd: "<password>", roles: [ { role: "readWrite", db: "misskey" } ] } )` Create the misskey user. | ||||
| 4. `exit` You're done! | ||||
|  | ||||
| *4.* Install Misskey | ||||
| ---------------------------------------------------------------- | ||||
| 1. Connect to misskey user. | ||||
|  | ||||
| 	`su - misskey` | ||||
|  | ||||
| 2. Clone the misskey repo from master branch. | ||||
|  | ||||
| 	`git clone -b master git://github.com/syuilo/misskey.git` | ||||
|  | ||||
| 3. Navigate to misskey directory | ||||
|  | ||||
| 	`cd misskey` | ||||
|  | ||||
| 4. Checkout to the [latest release](https://github.com/syuilo/misskey/releases/latest) | ||||
|  | ||||
| 	```bash | ||||
| 	git tag | grep '^10\.' | sort -V --reverse | \ | ||||
| 	while read tag_name; do \ | ||||
| 	if ! curl -s "https://api.github.com/repos/syuilo/misskey/releases/tags/$tag_name" \ | ||||
| 	| grep -qE '"(draft|prerelease)": true'; \ | ||||
| 	then git checkout $tag_name; break; fi ; done | ||||
| 	``` | ||||
|  | ||||
| 5. Install misskey dependencies. | ||||
|  | ||||
| 	`npm install` | ||||
|  | ||||
| *5.* Configure Misskey | ||||
| ---------------------------------------------------------------- | ||||
| 1. Copy the `.config/example.yml` and rename it to `default.yml`. | ||||
|  | ||||
| 	`cp .config/example.yml .config/default.yml` | ||||
|  | ||||
| 2. Edit `default.yml` | ||||
|  | ||||
| *6.* Build Misskey | ||||
| ---------------------------------------------------------------- | ||||
|  | ||||
| Build misskey with the following: | ||||
|  | ||||
| `NODE_ENV=production npm run build` | ||||
|  | ||||
| If you're on Debian, you will need to install the `build-essential`, `python` package. | ||||
|  | ||||
| If you're still encountering errors about some modules, use node-gyp: | ||||
|  | ||||
| 1. `npm install -g node-gyp` | ||||
| 2. `node-gyp configure` | ||||
| 3. `node-gyp build` | ||||
| 4. `NODE_ENV=production npm run build` | ||||
|  | ||||
| *7.* That is it. | ||||
| ---------------------------------------------------------------- | ||||
| Well done! Now, you have an environment that run to Misskey. | ||||
|  | ||||
| ### Launch normally | ||||
| Just `NODE_ENV=production npm start`. GLHF! | ||||
|  | ||||
| ### Launch with systemd | ||||
|  | ||||
| 1. Create a systemd service here | ||||
|  | ||||
| 	`/etc/systemd/system/misskey.service` | ||||
|  | ||||
| 2. Edit it, and paste this and save: | ||||
|  | ||||
| 	``` | ||||
| 	[Unit] | ||||
| 	Description=Misskey daemon | ||||
|  | ||||
| 	[Service] | ||||
| 	Type=simple | ||||
| 	User=misskey | ||||
| 	ExecStart=/usr/bin/npm start | ||||
| 	WorkingDirectory=/home/misskey/misskey | ||||
| 	Environment="NODE_ENV=production" | ||||
| 	TimeoutSec=60 | ||||
| 	StandardOutput=syslog | ||||
| 	StandardError=syslog | ||||
| 	SyslogIdentifier=misskey | ||||
| 	Restart=always | ||||
|  | ||||
| 	[Install] | ||||
| 	WantedBy=multi-user.target | ||||
| 	``` | ||||
|  | ||||
| 3. Reload systemd and enable the misskey service. | ||||
|  | ||||
| 	`systemctl daemon-reload ; systemctl enable misskey` | ||||
|  | ||||
| 4. Start the misskey service. | ||||
|  | ||||
| 	`systemctl start misskey` | ||||
|  | ||||
| You can check if the service is running with `systemctl status misskey`. | ||||
|  | ||||
| ### How to update your Misskey server to the latest version | ||||
| 1. `git fetch` | ||||
| 2.   | ||||
|  | ||||
| 	```bash | ||||
| 	git tag | grep '^10\.' | sort -V --reverse | \ | ||||
| 	while read tag_name; do \ | ||||
| 	if ! curl -s "https://api.github.com/repos/syuilo/misskey/releases/tags/$tag_name" \ | ||||
| 	| grep -qE '"(draft|prerelease)": true'; \ | ||||
| 	then git checkout $tag_name; break; fi ; done | ||||
| 	``` | ||||
| 3. `npm install` | ||||
| 4. `NODE_ENV=production npm run build` | ||||
| 5. Check [ChangeLog](../CHANGELOG.md) for migration information | ||||
| 6. Restart your Misskey process to apply changes | ||||
| 7. Enjoy | ||||
|  | ||||
| ---------------------------------------------------------------- | ||||
|  | ||||
| If you have any questions or troubles, feel free to contact us! | ||||
							
								
								
									
										156
									
								
								docs/setup.fr.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,156 @@ | ||||
| Guide d'installation et de configuration de Misskey | ||||
| ================================================================ | ||||
|  | ||||
| Nous vous remerçions de l'intrêt que vous manifestez pour l'installation de votre propre instance Misskey ! | ||||
| Ce guide décrit les étapes à suivre afin d'installer et de configurer une instance Misskey. | ||||
|  | ||||
| [La version en japonnais est également disponible sur - 日本語版もあります](./setup.ja.md) | ||||
|  | ||||
| ---------------------------------------------------------------- | ||||
|  | ||||
| *1.* Création de l'utilisateur Misskey | ||||
| ---------------------------------------------------------------- | ||||
| Executer misskey en tant que super-utilisateur étant une mauvaise idée, nous allons créer un utilisateur dédié. | ||||
| Sous Debian, par exemple : | ||||
|  | ||||
| ``` | ||||
| adduser --disabled-password --disabled-login misskey | ||||
| ``` | ||||
|  | ||||
| *2.* Installation des dépendances | ||||
| ---------------------------------------------------------------- | ||||
| Installez les paquets suivants : | ||||
|  | ||||
| #### Dépendences :package: | ||||
| * **[Node.js](https://nodejs.org/en/)** >= 10.0.0 | ||||
| * **[MongoDB](https://www.mongodb.com/)** >= 3.6 | ||||
|  | ||||
| ##### Optionnels | ||||
| * [Redis](https://redis.io/) | ||||
|   * Redis est optionnel mais nous vous recommandons vivement de l'installer | ||||
| * [Elasticsearch](https://www.elastic.co/) - requis pour pouvoir activer la fonctionnalité de recherche | ||||
| * [FFmpeg](https://www.ffmpeg.org/) | ||||
|  | ||||
| *3.* Paramètrage de MongoDB | ||||
| ---------------------------------------------------------------- | ||||
| En root : | ||||
| 1. `mongo` Ouvrez le shell mongo | ||||
| 2. `use misskey` Utilisez la base de données misskey | ||||
| 3. `db.createUser( { user: "misskey", pwd: "<password>", roles: [ { role: "readWrite", db: "misskey" } ] } )` Créez l'utilisateur misskey. | ||||
| 4. `exit` Vous avez terminé ! | ||||
|  | ||||
| *4.* Installation de Misskey | ||||
| ---------------------------------------------------------------- | ||||
| 1. Basculez vers l'utilisateur misskey. | ||||
|  | ||||
| 	`su - misskey` | ||||
|  | ||||
| 2. Clonez la branche master du dépôt misskey. | ||||
|  | ||||
| 	`git clone -b master git://github.com/syuilo/misskey.git` | ||||
|  | ||||
| 3. Accédez au dossier misskey. | ||||
|  | ||||
| 	`cd misskey` | ||||
|  | ||||
| 4. Checkout sur le tag de la [version la plus récente](https://github.com/syuilo/misskey/releases/latest) | ||||
|  | ||||
| 	```bash | ||||
| 	git tag | grep '^10\.' | sort -V --reverse | \ | ||||
| 	while read tag_name; do \ | ||||
| 	if ! curl -s "https://api.github.com/repos/syuilo/misskey/releases/tags/$tag_name" \ | ||||
| 	| grep -qE '"(draft|prerelease)": true'; \ | ||||
| 	then git checkout $tag_name; break; fi ; done | ||||
| 	``` | ||||
|   | ||||
| 5. Installez les dépendances de misskey. | ||||
|  | ||||
| 	`npm install` | ||||
|  | ||||
| *5.* Création du fichier de configuration | ||||
| ---------------------------------------------------------------- | ||||
| 1. Copiez le fichier `.config/example.yml` et renommez-le`default.yml`. | ||||
|  | ||||
| 	`cp .config/example.yml .config/default.yml` | ||||
|  | ||||
| 2. Editez le fichier `default.yml` | ||||
|  | ||||
| *6.* Construction de Misskey | ||||
| ---------------------------------------------------------------- | ||||
|  | ||||
| Construisez Misskey comme ceci : | ||||
|  | ||||
| `NODE_ENV=production npm run build` | ||||
|  | ||||
| Si vous êtes sous Debian, vous serez amené à installer les paquets `build-essential` et `python`. | ||||
|  | ||||
| Si vous rencontrez des erreurs concernant certains modules, utilisez node-gyp: | ||||
|  | ||||
| 1. `npm install -g node-gyp` | ||||
| 2. `node-gyp configure` | ||||
| 3. `node-gyp build` | ||||
| 4. `NODE_ENV=production npm run build` | ||||
|  | ||||
| *7.* C'est tout. | ||||
| ---------------------------------------------------------------- | ||||
| Excellent ! Maintenant, vous avez un environnement prêt pour lancer Misskey | ||||
|  | ||||
| ### Lancement conventionnel | ||||
| Lancez tout simplement `NODE_ENV=production npm start`. Bonne chance et amusez-vous bien ! | ||||
|  | ||||
| ### Démarrage avec systemd | ||||
|  | ||||
| 1. Créez un service systemd sur | ||||
|  | ||||
| 	`/etc/systemd/system/misskey.service` | ||||
|  | ||||
| 2. Editez-le puis copiez et coller ceci dans le fichier : | ||||
|  | ||||
| 	``` | ||||
| 	[Unit] | ||||
| 	Description=Misskey daemon | ||||
|  | ||||
| 	[Service] | ||||
| 	Type=simple | ||||
| 	User=misskey | ||||
| 	ExecStart=/usr/bin/npm start | ||||
| 	WorkingDirectory=/home/misskey/misskey | ||||
| 	Environment="NODE_ENV=production" | ||||
| 	TimeoutSec=60 | ||||
| 	StandardOutput=syslog | ||||
| 	StandardError=syslog | ||||
| 	SyslogIdentifier=misskey | ||||
| 	Restart=always | ||||
|  | ||||
| 	[Install] | ||||
| 	WantedBy=multi-user.target | ||||
| 	``` | ||||
|  | ||||
| 3. Redémarre systemd et active le service misskey. | ||||
|  | ||||
| 	`systemctl daemon-reload ; systemctl enable misskey` | ||||
|  | ||||
| 4. Démarre le service misskey. | ||||
|  | ||||
| 	`systemctl start misskey` | ||||
|  | ||||
| Vous pouvez vérifier si le service a démarré en utilisant la commande `systemctl status misskey`. | ||||
|  | ||||
| ### Méthode de mise à jour vers la plus récente version de Misskey | ||||
| 1. `git fetch` | ||||
| 2.   | ||||
|  | ||||
| 	```bash | ||||
| 	git tag | grep '^10\.' | sort -V --reverse | \ | ||||
| 	while read tag_name; do \ | ||||
| 	if ! curl -s "https://api.github.com/repos/syuilo/misskey/releases/tags/$tag_name" \ | ||||
| 	| grep -qE '"(draft|prerelease)": true'; \ | ||||
| 	then git checkout $tag_name; break; fi ; done | ||||
| 	``` | ||||
| 3. `npm install` | ||||
| 4. `NODE_ENV=production npm run build` | ||||
| 5. Consultez [ChangeLog](../CHANGELOG.md) pour les information de migration. | ||||
|  | ||||
| ---------------------------------------------------------------- | ||||
|  | ||||
| Si vous rencontrez des difficultés ou avez d'autres questions, n'hésitez pas à nous contacter ! | ||||
							
								
								
									
										166
									
								
								docs/setup.ja.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,166 @@ | ||||
| Misskey構築の手引き | ||||
| ================================================================ | ||||
|  | ||||
| Misskeyサーバーの構築にご関心をお寄せいただきありがとうございます! | ||||
| このガイドではMisskeyのインストール・セットアップ方法について解説します。 | ||||
|  | ||||
| [英語版もあります - English version also available](./setup.en.md) | ||||
|  | ||||
| ---------------------------------------------------------------- | ||||
|  | ||||
| *1.* Misskeyユーザーの作成 | ||||
| ---------------------------------------------------------------- | ||||
| Misskeyはrootユーザーで実行しない方がよいため、代わりにユーザーを作成します。 | ||||
| Debianの例: | ||||
|  | ||||
| ``` | ||||
| adduser --disabled-password --disabled-login misskey | ||||
| ``` | ||||
|  | ||||
| *2.* 依存関係をインストールする | ||||
| ---------------------------------------------------------------- | ||||
| これらのソフトウェアをインストール・設定してください: | ||||
|  | ||||
| #### 依存関係 :package: | ||||
| * **[Node.js](https://nodejs.org/en/)** (10.0.0以上) | ||||
| * **[MongoDB](https://www.mongodb.com/)** (3.6以上) | ||||
|  | ||||
| ##### オプション | ||||
| * [Redis](https://redis.io/) | ||||
| 	* Redisはオプションですが、インストールすることを強く推奨します。 | ||||
| 	* インストールしなくていいのは、あなたのインスタンスが自分専用のときだけとお考えください。 | ||||
| 	* 具体的には、Redisをインストールしないと、次の事が出来なくなります: | ||||
| 		* Misskeyプロセスを複数起動しての負荷分散 | ||||
| 		* レートリミット | ||||
| 		* ジョブキュー | ||||
| 		* Twitter連携 | ||||
| * [Elasticsearch](https://www.elastic.co/) | ||||
| 	* 検索機能を有効にするためにはインストールが必要です。 | ||||
| * [FFmpeg](https://www.ffmpeg.org/) | ||||
|  | ||||
| *3.* MongoDBの設定 | ||||
| ---------------------------------------------------------------- | ||||
| ルートで: | ||||
| 1. `mongo` mongoシェルを起動 | ||||
| 2. `use misskey` misskeyデータベースを使用 | ||||
| 3. `db.createUser( { user: "misskey", pwd: "<password>", roles: [ { role: "readWrite", db: "misskey" } ] } )` misskeyユーザーを作成 | ||||
| 4. `exit` mongoシェルを終了 | ||||
|  | ||||
| *4.* Misskeyのインストール | ||||
| ---------------------------------------------------------------- | ||||
| 1. misskeyユーザーを使用 | ||||
|  | ||||
| 	`su - misskey` | ||||
|  | ||||
| 2. masterブランチからMisskeyレポジトリをクローン | ||||
|  | ||||
| 	`git clone -b master git://github.com/syuilo/misskey.git` | ||||
|  | ||||
| 3. misskeyディレクトリに移動 | ||||
|  | ||||
| 	`cd misskey` | ||||
|  | ||||
| 4. [最新のリリース](https://github.com/syuilo/misskey/releases/latest)を確認 | ||||
|  | ||||
| 	```bash | ||||
| 	git tag | grep '^10\.' | sort -V --reverse | \ | ||||
| 	while read tag_name; do \ | ||||
| 	if ! curl -s "https://api.github.com/repos/syuilo/misskey/releases/tags/$tag_name" \ | ||||
| 	| grep -qE '"(draft|prerelease)": true'; \ | ||||
| 	then git checkout $tag_name; break; fi ; done | ||||
| 	``` | ||||
|  | ||||
| 5. Misskeyの依存パッケージをインストール | ||||
|  | ||||
| 	`npm install` | ||||
|  | ||||
| *5.* 設定ファイルを作成する | ||||
| ---------------------------------------------------------------- | ||||
| 1. `.config/example.yml`をコピーし名前を`default.yml`にする。 | ||||
|  | ||||
| 	`cp .config/example.yml .config/default.yml` | ||||
|  | ||||
| 2. `default.yml` を編集する。 | ||||
|  | ||||
| *6.* Misskeyのビルド | ||||
| ---------------------------------------------------------------- | ||||
|  | ||||
| 次のコマンドでMisskeyをビルドしてください: | ||||
|  | ||||
| `NODE_ENV=production npm run build` | ||||
|  | ||||
| Debianをお使いであれば、`build-essential`パッケージをインストールする必要があります。 | ||||
|  | ||||
| 何らかのモジュールでエラーが発生する場合はnode-gypを使ってください: | ||||
| 1. `npm install -g node-gyp` | ||||
| 2. `node-gyp configure` | ||||
| 3. `node-gyp build` | ||||
| 4. `NODE_ENV=production npm run build` | ||||
|  | ||||
| *7.* 以上です! | ||||
| ---------------------------------------------------------------- | ||||
| お疲れ様でした。これでMisskeyを動かす準備は整いました。 | ||||
|  | ||||
| ### 通常起動 | ||||
| `NODE_ENV=production npm start`するだけです。GLHF! | ||||
|  | ||||
| ### systemdを用いた起動 | ||||
| 1. systemdサービスのファイルを作成 | ||||
|  | ||||
| 	`/etc/systemd/system/misskey.service` | ||||
|  | ||||
| 2. エディタで開き、以下のコードを貼り付けて保存: | ||||
|  | ||||
| 	``` | ||||
| 	[Unit] | ||||
| 	Description=Misskey daemon | ||||
|  | ||||
| 	[Service] | ||||
| 	Type=simple | ||||
| 	User=misskey | ||||
| 	ExecStart=/usr/bin/npm start | ||||
| 	WorkingDirectory=/home/misskey/misskey | ||||
| 	Environment="NODE_ENV=production" | ||||
| 	TimeoutSec=60 | ||||
| 	StandardOutput=syslog | ||||
| 	StandardError=syslog | ||||
| 	SyslogIdentifier=misskey | ||||
| 	Restart=always | ||||
|  | ||||
| 	[Install] | ||||
| 	WantedBy=multi-user.target | ||||
| 	``` | ||||
|  | ||||
| 	CentOSで1024以下のポートを使用してMisskeyを使用する場合は`ExecStart=/usr/bin/sudo /usr/bin/npm start`に変更する必要があります。 | ||||
|  | ||||
| 3. systemdを再読み込みしmisskeyサービスを有効化 | ||||
|  | ||||
| 	`systemctl daemon-reload ; systemctl enable misskey` | ||||
|  | ||||
| 4. misskeyサービスの起動 | ||||
|  | ||||
| 	`systemctl start misskey` | ||||
|  | ||||
| `systemctl status misskey`と入力すると、サービスの状態を調べることができます。 | ||||
|  | ||||
| ### Misskeyを最新バージョンにアップデートする方法: | ||||
| 1. `git fetch` | ||||
| 2.   | ||||
|  | ||||
| 	```bash | ||||
| 	git tag | grep '^10\.' | sort -V --reverse | \ | ||||
| 	while read tag_name; do \ | ||||
| 	if ! curl -s "https://api.github.com/repos/syuilo/misskey/releases/tags/$tag_name" \ | ||||
| 	| grep -qE '"(draft|prerelease)": true'; \ | ||||
| 	then git checkout $tag_name; break; fi ; done | ||||
| 	``` | ||||
|  | ||||
| 3. `npm install` | ||||
| 4. `NODE_ENV=production npm run build` | ||||
| 5. [ChangeLog](../CHANGELOG.md)でマイグレーション情報を確認する | ||||
|  | ||||
| なにか問題が発生した場合は、`npm run clean`または`npm run cleanall`すると直る場合があります。 | ||||
|  | ||||
| ---------------------------------------------------------------- | ||||
|  | ||||
| なにかお困りのことがありましたらお気軽にご連絡ください。 | ||||
							
								
								
									
										65
									
								
								gulpfile.js
									
									
									
									
									
								
							
							
						
						| @@ -1,65 +0,0 @@ | ||||
| /** | ||||
|  * 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:fontawesome', () => | ||||
| 	gulp.src('./packages/client/node_modules/@fortawesome/fontawesome-free/**/*').pipe(gulp.dest('./built/_client_dist_/fontawesome/')) | ||||
| ); | ||||
|  | ||||
| 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('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', 'copy:client:fontawesome' | ||||
| )); | ||||
|  | ||||
| gulp.task('default', gulp.task('build')); | ||||
|  | ||||
| gulp.task('watch', () => { | ||||
| 	gulp.watch([ | ||||
| 		'./packages/*/src/**/*', | ||||
| 	], { ignoreInitial: false }, gulp.task('build')); | ||||
| }); | ||||
							
								
								
									
										148
									
								
								gulpfile.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,148 @@ | ||||
| /** | ||||
|  * Gulp tasks | ||||
|  */ | ||||
|  | ||||
| import * as gulp from 'gulp'; | ||||
| import * as gutil from 'gulp-util'; | ||||
| import * as ts from 'gulp-typescript'; | ||||
| const sourcemaps = require('gulp-sourcemaps'); | ||||
| import tslint from 'gulp-tslint'; | ||||
| const cssnano = require('gulp-cssnano'); | ||||
| const stylus = require('gulp-stylus'); | ||||
| import * as uglifyComposer from 'gulp-uglify/composer'; | ||||
| import * as rimraf from 'rimraf'; | ||||
| import chalk from 'chalk'; | ||||
| const imagemin = require('gulp-imagemin'); | ||||
| import * as rename from 'gulp-rename'; | ||||
| import * as mocha from 'gulp-mocha'; | ||||
| import * as replace from 'gulp-replace'; | ||||
| const uglifyes = require('uglify-es'); | ||||
|  | ||||
| const locales = require('./locales'); | ||||
|  | ||||
| const uglify = uglifyComposer(uglifyes, console); | ||||
|  | ||||
| const env = process.env.NODE_ENV || 'development'; | ||||
| const isProduction = env === 'production'; | ||||
| const isDebug = !isProduction; | ||||
|  | ||||
| if (isDebug) { | ||||
| 	console.warn(chalk.yellow.bold('WARNING! NODE_ENV is not "production".')); | ||||
| 	console.warn(chalk.yellow.bold('         built script will not be compressed.')); | ||||
| } | ||||
|  | ||||
| gulp.task('build:ts', () => { | ||||
| 	const tsProject = ts.createProject('./tsconfig.json'); | ||||
|  | ||||
| 	return tsProject | ||||
| 		.src() | ||||
| 		.pipe(sourcemaps.init()) | ||||
| 		.pipe(tsProject()) | ||||
| 		.on('error', () => {}) | ||||
| 		.pipe(sourcemaps.write('.', { includeContent: false, sourceRoot: '../built' })) | ||||
| 		.pipe(gulp.dest('./built/')); | ||||
| }); | ||||
|  | ||||
| gulp.task('build:copy:views', () => | ||||
| 	gulp.src('./src/server/web/views/**/*').pipe(gulp.dest('./built/server/web/views')) | ||||
| ); | ||||
|  | ||||
| gulp.task('build:copy', gulp.parallel('build:copy:views', () => | ||||
| 	gulp.src([ | ||||
| 		'./build/Release/crypto_key.node', | ||||
| 		'./src/const.json', | ||||
| 		'./src/server/web/views/**/*', | ||||
| 		'./src/**/assets/**/*', | ||||
| 		'!./src/client/app/**/assets/**/*' | ||||
| 	]).pipe(gulp.dest('./built/')) | ||||
| )); | ||||
|  | ||||
| gulp.task('lint', () => | ||||
| 	gulp.src('./src/**/*.ts') | ||||
| 		.pipe(tslint({ | ||||
| 			formatter: 'verbose' | ||||
| 		})) | ||||
| 		.pipe(tslint.report()) | ||||
| ); | ||||
|  | ||||
| gulp.task('format', () => | ||||
| 	gulp.src('./src/**/*.ts') | ||||
| 		.pipe(tslint({ | ||||
| 			formatter: 'verbose', | ||||
| 			fix: true | ||||
| 		})) | ||||
| 		.pipe(tslint.report()) | ||||
| ); | ||||
|  | ||||
| gulp.task('mocha', () => | ||||
| 	gulp.src('./test/**/*.ts') | ||||
| 		.pipe(mocha({ | ||||
| 			exit: true, | ||||
| 			require: 'ts-node/register' | ||||
| 		} as any)) | ||||
| ); | ||||
|  | ||||
| gulp.task('test', gulp.task('mocha')); | ||||
|  | ||||
| gulp.task('clean', cb => | ||||
| 	rimraf('./built', cb) | ||||
| ); | ||||
|  | ||||
| gulp.task('cleanall', gulp.parallel('clean', cb => | ||||
| 	rimraf('./node_modules', cb) | ||||
| )); | ||||
|  | ||||
| gulp.task('build:client:script', () => { | ||||
| 	const client = require('./built/client/meta.json'); | ||||
| 	return gulp.src(['./src/client/app/boot.js', './src/client/app/safe.js']) | ||||
| 		.pipe(replace('VERSION', JSON.stringify(client.version))) | ||||
| 		.pipe(replace('ENV', JSON.stringify(env))) | ||||
| 		.pipe(replace('LANGS', JSON.stringify(Object.keys(locales)))) | ||||
| 		.pipe(isProduction ? uglify({ | ||||
| 			toplevel: true | ||||
| 		} as any) : gutil.noop()) | ||||
| 		.pipe(gulp.dest('./built/client/assets/')); | ||||
| }); | ||||
|  | ||||
| gulp.task('build:client:styles', () => | ||||
| 	gulp.src('./src/client/app/init.css') | ||||
| 		.pipe(isProduction | ||||
| 			? (cssnano as any)() | ||||
| 			: gutil.noop()) | ||||
| 		.pipe(gulp.dest('./built/client/assets/')) | ||||
| ); | ||||
|  | ||||
| gulp.task('copy:client', () => | ||||
| 		gulp.src([ | ||||
| 			'./assets/**/*', | ||||
| 			'./src/client/assets/**/*', | ||||
| 			'./src/client/app/*/assets/**/*' | ||||
| 		]) | ||||
| 			.pipe(isProduction ? (imagemin as any)() : gutil.noop()) | ||||
| 			.pipe(rename(path => { | ||||
| 				path.dirname = path.dirname.replace('assets', '.'); | ||||
| 			})) | ||||
| 			.pipe(gulp.dest('./built/client/assets/')) | ||||
| ); | ||||
|  | ||||
| gulp.task('doc', () => | ||||
| 	gulp.src('./src/docs/**/*.styl') | ||||
| 		.pipe(stylus()) | ||||
| 		.pipe((cssnano as any)()) | ||||
| 		.pipe(gulp.dest('./built/docs/assets/')) | ||||
| ); | ||||
|  | ||||
| gulp.task('build:client', gulp.parallel( | ||||
| 	'build:client:script', | ||||
| 	'build:client:styles', | ||||
| 	'copy:client' | ||||
| )); | ||||
|  | ||||
| gulp.task('build', gulp.parallel( | ||||
| 	'build:ts', | ||||
| 	'build:copy', | ||||
| 	'build:client', | ||||
| 	'doc' | ||||
| )); | ||||
|  | ||||
| gulp.task('default', gulp.task('build')); | ||||