2019-02-24 04:40:17 +01:00
|
|
|
|
import config from '../../../config';
|
2019-04-15 05:20:48 +02:00
|
|
|
|
import endpoints from '../endpoints';
|
|
|
|
|
import * as locale from '../../../../locales/';
|
|
|
|
|
import { fromEntries } from '../../../prelude/array';
|
|
|
|
|
import { kinds as kindsList } from '../kinds';
|
|
|
|
|
|
|
|
|
|
export interface IKindInfo {
|
|
|
|
|
endpoints: string[];
|
|
|
|
|
descs: { [x: string]: string; };
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
export function kinds() {
|
|
|
|
|
const kinds = fromEntries(
|
|
|
|
|
kindsList
|
|
|
|
|
.map(k => [k, {
|
|
|
|
|
endpoints: [],
|
|
|
|
|
descs: fromEntries(
|
|
|
|
|
Object.keys(locale)
|
2020-02-15 15:13:59 +01:00
|
|
|
|
.map(l => [l, locale[l]._permissions[k] as string] as [string, string])
|
2019-04-15 05:20:48 +02:00
|
|
|
|
) as { [x: string]: string; }
|
|
|
|
|
}] as [ string, IKindInfo ])
|
|
|
|
|
) as { [x: string]: IKindInfo; };
|
|
|
|
|
|
|
|
|
|
const errors = [] as string[][];
|
|
|
|
|
|
|
|
|
|
for (const endpoint of endpoints.filter(ep => !ep.meta.secure)) {
|
|
|
|
|
if (endpoint.meta.kind) {
|
|
|
|
|
const kind = endpoint.meta.kind;
|
|
|
|
|
if (kind in kinds) kinds[kind].endpoints.push(endpoint.name);
|
|
|
|
|
else errors.push([kind, endpoint.name]);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (errors.length > 0) throw Error('\n ' + errors.map((e) => `Unknown kind (permission) "${e[0]}" found at ${e[1]}.`).join('\n '));
|
|
|
|
|
|
|
|
|
|
return kinds;
|
|
|
|
|
}
|
2019-04-15 05:10:40 +02:00
|
|
|
|
|
|
|
|
|
export function getDescription(lang = 'ja-JP'): string {
|
|
|
|
|
const permissionTable = (Object.entries(kinds()) as [string, IKindInfo][])
|
|
|
|
|
.map(e => `|${e[0]}|${e[1].descs[lang]}|${e[1].endpoints.map(f => `[${f}](#operation/${f})`).join(', ')}|`)
|
|
|
|
|
.join('\n');
|
|
|
|
|
|
|
|
|
|
const descriptions = {
|
|
|
|
|
'ja-JP': `**Misskey is a decentralized microblogging platform.**
|
2019-02-24 04:40:17 +01:00
|
|
|
|
|
2019-04-23 15:35:26 +02:00
|
|
|
|
# Usage
|
2019-02-23 20:11:54 +01:00
|
|
|
|
**APIはすべてPOSTでリクエスト/レスポンスともにJSON形式です。**
|
2019-02-24 20:18:09 +01:00
|
|
|
|
一部のAPIはリクエストに認証情報(APIキー)が必要です。リクエストの際に\`i\`というパラメータでAPIキーを添付してください。
|
2019-02-23 20:08:08 +01:00
|
|
|
|
|
2019-04-23 15:35:26 +02:00
|
|
|
|
## 自分のアカウントのAPIキーを取得する
|
2019-02-24 20:18:09 +01:00
|
|
|
|
「設定 > API」で、自分のAPIキーを取得できます。
|
2019-02-23 20:08:08 +01:00
|
|
|
|
|
|
|
|
|
> アカウントを不正利用される可能性があるため、このトークンは第三者に教えないでください(アプリなどにも入力しないでください)。
|
|
|
|
|
|
2019-04-23 15:35:26 +02:00
|
|
|
|
## アプリケーションとしてAPIキーを取得する
|
2019-02-24 20:18:09 +01:00
|
|
|
|
直接ユーザーのAPIキーをアプリケーションが扱うのはセキュリティ上のリスクがあるので、
|
|
|
|
|
アプリケーションからAPIを利用する際には、アプリケーションとアプリケーションを利用するユーザーが結び付けられた専用のAPIキーを発行します。
|
2019-02-23 20:08:08 +01:00
|
|
|
|
|
2019-04-23 15:35:26 +02:00
|
|
|
|
### 1.アプリケーションを登録する
|
2019-02-23 20:08:08 +01:00
|
|
|
|
まず、あなたのアプリケーションやWebサービス(以後、あなたのアプリと呼びます)をMisskeyに登録します。
|
|
|
|
|
[デベロッパーセンター](/dev)にアクセスし、「アプリ > アプリ作成」からアプリを作成してください。
|
|
|
|
|
|
|
|
|
|
登録が済むとあなたのアプリのシークレットキーが入手できます。このシークレットキーは後で使用します。
|
|
|
|
|
|
|
|
|
|
> アプリに成りすまされる可能性があるため、極力このシークレットキーは公開しないようにしてください。</p>
|
|
|
|
|
|
2019-04-23 15:35:26 +02:00
|
|
|
|
### 2.ユーザーに認証させる
|
2019-02-23 20:08:08 +01:00
|
|
|
|
アプリを使ってもらうには、ユーザーにアカウントへのアクセスの許可をもらう必要があります。
|
|
|
|
|
|
2019-02-24 20:18:09 +01:00
|
|
|
|
認証セッションを開始するには、[${config.apiUrl}/auth/session/generate](#operation/auth/session/generate) へパラメータに\`appSecret\`としてシークレットキーを含めたリクエストを送信します。
|
2019-02-23 20:08:08 +01:00
|
|
|
|
レスポンスとして認証セッションのトークンや認証フォームのURLが取得できるので、認証フォームのURLをブラウザで表示し、ユーザーにフォームを提示してください。
|
|
|
|
|
|
|
|
|
|
あなたのアプリがコールバックURLを設定している場合、
|
2019-02-24 04:40:17 +01:00
|
|
|
|
ユーザーがあなたのアプリの連携を許可すると設定しているコールバックURLに\`token\`という名前でセッションのトークンが含まれたクエリを付けてリダイレクトします。
|
2019-02-23 20:08:08 +01:00
|
|
|
|
|
|
|
|
|
あなたのアプリがコールバックURLを設定していない場合、ユーザーがあなたのアプリの連携を許可したことを(何らかの方法で(たとえばボタンを押させるなど))確認出来るようにしてください。
|
|
|
|
|
|
2019-04-23 15:35:26 +02:00
|
|
|
|
### 3.アクセストークンを取得する
|
2019-02-24 04:53:22 +01:00
|
|
|
|
ユーザーが連携を許可したら、[${config.apiUrl}/auth/session/userkey](#operation/auth/session/userkey) へリクエストを送信します。
|
2019-02-23 20:08:08 +01:00
|
|
|
|
|
2019-02-24 20:18:09 +01:00
|
|
|
|
上手くいけば、認証したユーザーのアクセストークンがレスポンスとして取得できます。おめでとうございます!
|
2019-02-23 20:08:08 +01:00
|
|
|
|
|
2019-02-24 20:18:09 +01:00
|
|
|
|
アクセストークンが取得できたら、*「ユーザーのアクセストークン+あなたのアプリのシークレットキーをsha256したもの」*をAPIキーとして、APIにリクエストできます。
|
2019-02-23 20:08:08 +01:00
|
|
|
|
|
2019-02-24 20:18:09 +01:00
|
|
|
|
APIキーの生成方法を擬似コードで表すと次のようになります:
|
2019-02-24 04:40:17 +01:00
|
|
|
|
\`\`\` js
|
|
|
|
|
const i = sha256(userToken + secretKey);
|
|
|
|
|
\`\`\`
|
2019-04-15 05:10:40 +02:00
|
|
|
|
|
2019-04-23 15:35:26 +02:00
|
|
|
|
# Permissions
|
2019-04-15 05:10:40 +02:00
|
|
|
|
|Permisson (kind)|Description|Endpoints|
|
|
|
|
|
|:--|:--|:--|
|
|
|
|
|
${permissionTable}
|
|
|
|
|
`
|
|
|
|
|
} as { [x: string]: string };
|
|
|
|
|
return lang in descriptions ? descriptions[lang] : descriptions['ja-JP'];
|
|
|
|
|
}
|