Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
Blueskyに伏せ字投稿ができるWebアプリの作り方
Search
ENDO Yasuyuki
February 21, 2024
Technology
0
520
Blueskyに伏せ字投稿ができるWebアプリの作り方
Blueskyに伏せ字投稿ができるWebアプリ、Bluespoilerの技術寄りの発表資料です。
ENDO Yasuyuki
February 21, 2024
Tweet
Share
More Decks by ENDO Yasuyuki
See All by ENDO Yasuyuki
Bluespoilerのご紹介
eyasuyuki
0
440
幻のテスト技法「キーワード駆動テスト」を追い求めて
eyasuyuki
0
2.7k
キーワード駆動っぽいテストができるツールを開発した話
eyasuyuki
0
480
Kotlin Updates in LL2019
eyasuyuki
0
570
Learn Languages 2019
eyasuyuki
5
1.1k
Why Flutter excitement me?
eyasuyuki
3
1.1k
Kotlin vs Swift
eyasuyuki
0
520
フロントエンドだめ自慢
eyasuyuki
0
130
llot_frontend.pdf
eyasuyuki
0
56
Other Decks in Technology
See All in Technology
AI × クラウドで シイタケの収穫時期を判定してみた
lamaglama39
0
290
「データ無い! 腹立つ! 推論する!」から 「データ無い! 腹立つ! データを作る」へ チームでデータを作り、育てられるようにするまで / How can we create, use, and maintain data ourselves?
moznion
8
4.3k
Moto: Latent Motion Token as the Bridging Language for Learning Robot Manipulation from Videos
peisuke
0
150
JavaScript パーサーに using 対応をする過程で与えたエコシステムへの影響
baseballyama
1
100
米軍Platform One / Black Pearlに学ぶ極限環境DevSecOps
jyoshise
1
380
「もっと正確に、もっと効率的に」ANDPADの写真書き込み機能における、 現場の声を形にしたエンハンス
andpad
0
110
ソフトウェア開発現代史: 55%が変化に備えていない現実 ─ AI支援型開発時代のReboot Japan #agilejapan
takabow
7
4.2k
[mercari GEARS 2025] Keynote
mercari
PRO
1
270
はじめての OSS コントリビューション 〜小さな PR が世界を変える〜
chiroito
4
330
ユーザーストーリー x AI / User Stories x AI
oomatomo
0
190
Introducing RFC9111 / YAPC::Fukuoka 2025
k1low
1
250
AIと自動化がもたらす業務効率化の実例: 反社チェック等の調査・業務プロセス自動化
enpipi
0
600
Featured
See All Featured
What's in a price? How to price your products and services
michaelherold
246
12k
Navigating Team Friction
lara
190
15k
What’s in a name? Adding method to the madness
productmarketing
PRO
24
3.8k
Building Adaptive Systems
keathley
44
2.8k
The Power of CSS Pseudo Elements
geoffreycrofte
80
6.1k
個人開発の失敗を避けるイケてる考え方 / tips for indie hackers
panda_program
118
20k
実際に使うSQLの書き方 徹底解説 / pgcon21j-tutorial
soudai
PRO
192
56k
Stop Working from a Prison Cell
hatefulcrawdad
272
21k
Statistics for Hackers
jakevdp
799
220k
Agile that works and the tools we love
rasmusluckow
331
21k
"I'm Feeling Lucky" - Building Great Search Experiences for Today's Users (#IAC19)
danielanewman
231
22k
How STYLIGHT went responsive
nonsquared
100
5.9k
Transcript
Bluesky に伏せ字投稿ができる Web ア プリの作り方 2024-02-21 Yasuyuki ENDO 1
GitHub リポジトリ https://github.com/eyasuyuki/bluespoiler/ 2
説明すること どうやって伏せ字投稿するのか なぜ作ろうと思ったのか なぜWeb サービスやモバイルアプリとしてリリースしなかったのか なぜFlutter で書いたのか 画像サイズチェック Bluesky への接続とテスト
記事URL の推測 今後の展開 3
説明しないこと fusetter の伏せ字アルゴリズムを勝手に推測する Flutter のライブラリの使い方 Riverpod Freezed go_router flutter_hooks image_picker_web
Rich Text でURL をリンクさせる 4
詳しくは Zenn に書きました。 https://zenn.dev/eyasuyuki/articles/825b28b0ec0a4c ※ イイネください.... 5
どうやって伏せ字投稿するのか https://eyasuyuki.github.io/bluespoiler/ [ と] の間の文が◦ になる(fusetter の再発明) ネタバレの本文は画像のALT に入る 6
伏せ字投稿 ネタバレ ALT 7
デモ https://youtu.be/eZX9s03MDQc?si=bgW2A1EWXn87TGWZ 8
なぜ作ろうと思ったのか Bluesky にはfusetter がないので だがfusetter みたいに自前サーバーを持つのは面倒 画像のALT なら1000 文字まで入れられる( 邪道)
自前バックエンドは持たずにBluesky とだけ通信すればいい 9
なぜ Web サービスやモバイルアプリと してリリースしなかったのか Web サービスは維持費がかかるし無料枠だとしても維持するのが大 変 当初はモバイルアプリ版も作ろうと思った Web アプリとして公開してiPhone
のホーム画面に追加してみた。ア プリ必要ないじゃん 失敗したのは何もログを取っていないこと( ユーザーにとってはメリ ット) 10
なぜ Flutter で書いたのか 当初はモバイルアプリ版も出そうと思っていた React やVue などWeb クライアントサイドの流行を追うのは大変 Flutter ならモバイルもWeb
もデスクトップも同時開発できる Flutter は2 年ぐらい触ってないのでキャッチアップしたかった Bluesky.dart の情報がすぐに見つかった 11
画像サイズチェック 976.56KB を超える画像をアップロードするとエラーになる 976.56KB 以下に圧縮を試みたがWeb クライアントサイドでは無理 そう 単に警告するだけにした 12
画像選択部分のコード ※ Dart は new を省略できます。 13
Bluesky への接続とテスト Article クラス 14
Bluesky への投稿 15
テスト とりあえず本当に接続してテストする 本物のID/ パスワードを隠蔽するために flutter_dotenv を使う .gitignore に .env を追加する
プロジェクトルートに .env ファイルを作成 16
テスト main 17
画像投稿のテスト ※ 本当に投稿されます。 18
記事 URL の推測 Bluesky にPost すると例えばこんな結果が返る。 {"uri":"at://did:plc:dptps7rgxju4nrg6qskop2wz/app.bsky.feed.post/3kjmvo7ocl62e", "cid":"bafyreihxcb3n6hxucw3hdeb3kylhzkoumitkx4hygoy24tyxt4hemajdde"} Bluesky の記事URL
はこんな感じ。 https://bsky.app/profile/javaopen.org/post/3kjmvo7ocl62e 3kjmvo7ocl62e が記事のID っぽい javaopen.org の部分は session.data.handle で取得できる 19
記事 URL の生成 20
投稿後の画面 21
今後の展開 認証方法の改善(Bluesky 待ち) ログをとる(Google Analytics?) 伏せ字投稿ランキング? 発表させていただきありがとうございました。 22