1119
645

More than 3 years have passed since last update.

エンジニア・プログラマにしか使えないSNSを作ってみた話

Last updated at Posted at 2021-07-16

はじめに

通常のSNSで胡散臭い人が多いと感じてしまいました
プログラミングスクールが流行り、エンジニアになって億稼いでます!みたいな・・・

そこで、本当のエンジニア・プログラマしか使えないSNSを作ってみました!
つまり、WebApi提供のみのSNSです
一般ピープルが使うようなフロントエンドなんてありません!!
Postmanなり、なんなりを使って叩いてください

エンジニア・プログラマしかWebApiが叩けないであろうという考えなので、
エンジニア・プログラマにしか使えないSNS!ということです

この記事を見ている、プログラマ・エンジニアの方であれば使えますよね?😁

実際、WebApiが叩くことが出来れば誰でも使えてしまうわけですが・・・。

2021/07/20 更新
このWebApiを作ったシステムについて書きました
ソースコード公開しました
CRUDのWebApi開発は不要!Json登録でWebApiを作れるシステムを作った話

2021/07/19 更新
結構使っていただけているようで嬉しい限りです
皆さん独自のクライアントなどを作って使われているようです
(curlで叩いてる人もいるっぽいです。CUIで使えるSNSというのは確かになあぁと思いました)
一部紹介させていただきます

2021/08/24 更新
無料枠550時間/月 の関係で現在サービスが停止しています・・・
来月の1日には復活します・・・。

匿名さん

にゃんこ仙人さん

15さん

目次

エンドポイント

https://versatileapi.herokuapp.com/api

ユーザー登録(しなくてもOK)

登録
POST /user/create_user

更新
PUT  /user/create_user

スキーマ

user.json
{
    "additionalProperties":false,
    "type": "object",
    "properties": {
        "name": {
            "description": "ユーザー名",
            "type": "string",
            "maxLength": 30
        },
        "description": {
            "description": "自己紹介文",
            "type": "string",
            "maxLength": 300
        }
    },
    "required": [
        "name",
        "description"
    ]
}

ユーザー検索

単一
GET /user/:user_id

全部
GET /user/all

つぶやく

つぶやく
POST /text

Headers
Authorization: HelloWorld

スキーマ

user.json
{
    "additionalProperties":false,
    "type": "object",
    "properties": {
        "text": {
            "description": "投稿する文章",
            "type": "string",
            "minLength": 1,
            "maxLength": 280
        },
        "in_reply_to_user_id": {
            "description": "返信対象のUserId",
            "type": "string",
            "minLength": 40,
            "maxLength": 40
        },            
        "in_reply_to_text_id": {
            "description": "返信対象のTextId",
            "type": "string",
            "minLength": 36,
            "maxLength": 36
        }
    },
    "required": [
        "text"
    ]
}

つぶやき検索

単一
GET /text/:id

全部
GET /text/all

ODataクエリによる検索(最新20件取得)
GET /text/all?$orderby=_created_at desc&$limit=20

ODataクエリは全て対応しているわけではありません
$filterなど基本的な部分は対応or,andも対応していますが、括弧()を使用する検索は対応していません

このWebApiのシステムについて

上記のWebApiはハードコーディングせずに定義を登録することで、WebApiが作成できるシステム上で動いています
例えば、下記のようなJsonを管理者用のAPIにPostするとWebApiが作られます
このシステムについては次回?記事を書こうと思います
書きました
CRUDのWebApi開発は不要!Json登録でWebApiを作れるシステムを作った話

text.json
{
    "apiSecret": "HelloWorld",
    "apiUrl":"text",
    "jsonSchema": {
        "additionalProperties":false,
        "type": "object",
        "properties": {
            "text": {
                "description": "投稿する文章",
                "type": "string",
                "minLength": 1,
                "maxLength": 280
            },
            "in_reply_to_user_id": {
                "description": "返信対象のUserId",
                "type": "string",
                "minLength": 40,
                "maxLength": 40
            },            
            "in_reply_to_text_id": {
                "description": "返信対象のTextId",
                "type": "string",
                "minLength": 36,
                "maxLength": 36
            }
        },
        "required": [
            "text"
        ]
    },
    "methodSettings": [
        {
            "httpMethod": "GET",
            "behavior": "Allow"
        },
        {
            "httpMethod": "POST",
            "behavior": "Authorization"
        },
        {
            "httpMethod": "PUT",
            "behavior": "NotImplemented"
        },
        {
            "httpMethod": "DELETE",
            "behavior": "NotImplemented"
        }
    ]
}
user.json
{
    "apiSecret": "",
    "apiUrl":"user",
    "jsonSchema": {
        "additionalProperties":false,
        "type": "object",
        "properties": {
            "name": {
                "description": "ユーザー名",
                "type": "string",
                "maxLength": 30
            },
            "description": {
                "description": "自己紹介文",
                "type": "string",
                "maxLength": 300
            }
        },
        "required": [
            "name",
            "description"
        ]
    },
    "methodSettings": [
        {
            "httpMethod": "GET",
            "behavior": "Allow"
        },
        {
            "httpMethod": "POST",
            "behavior": "IptoId"
        },
        {
            "httpMethod": "PUT",
            "behavior": "IptoId"
        },
        {
            "httpMethod": "DELETE",
            "behavior": "NotImplemented"
        }
    ]
}
1119
645
20

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
1119
645