Jekyll2022-12-31T22:27:13+09:00https://default.cf/blog/feed.xmldefault.cf/blogヲタクな話を書きます。さよなら、2022年2022-12-31T00:00:00+09:002022-12-31T00:00:00+09:00https://default.cf/blog/2022/12/31/goodbye-2022<p>今年も今年で、色々生活が変わった1年だった。</p>
<p>まず、10月に転職した。今月で丁度試用期間が終わるので明らかにするが、サイボウズ株式会社の生産性向上チームにジョインした。
モブプログラミングで業務を進める他、空いている時間に自分に足りていない知識、社内特有のツールなどへの理解をしてきた。
来年はバリバリ業務を進めつつ、インプットと外部への発信なども積極的にやっていきたい…2022年はこのブログも全然書いてなかったし…</p>
<h2 id="本">本</h2>
<p>(リストアップ中…)</p>
<h2 id="ガジェット類">ガジェット類</h2>
<ul>
<li>マザボ</li>
<li>RTX3090</li>
</ul>
<p>グラボを大幅にアップグレードした。これで <a href="https://xn--pckjp4dudxftf.xn--tckwe/">ゴーストクラブ.コム</a> の負荷に耐えられるようになった。最高。
そう、この1年はVRにドハマりし続けた1年だった。丁度去年 <a href="https://default.cf/blog/2021/12/26/oculus-quest-2/">こんなブログ記事</a> を書いていたが、VR の中で友達ができたよ…!毎晩 HMD 付けて酒を飲んで友達とお喋りしているよ…!
でもドハマりしすぎて、リアルでも VR でも友達の人にリアル蔑ろにしすぎって言われたので、2023年はバランスを考えるよ。</p>
<hr />
<p>さてこれからアバターを仕上げて、VR の中で友達と新年を迎えるんだ…!
来年もよろしくお願いします。</p>
<p>なお、本文章は走り書きのようなもので、サイレントに修正する予定なので悪しからず。</p>今年も今年で、色々生活が変わった1年だった。このブログにコメント欄を追加したよ2022-01-18T00:00:00+09:002022-01-18T00:00:00+09:00https://default.cf/blog/2022/01/18/add-comment-field<p>JavaScript ってやつでコメント欄増やした。</p>
<hr />
<p>このブログは今まで WEB 1.0 みたいなサイト運用をしてきたけど、
ここに来てコメント欄を増やしてみた。WEB 2.0 の到来である(笑)</p>
<p>「<a href="https://utteranc.es/">utterances 🔮</a>」というサービスを使って実現している。</p>
<p>データがどこに書き込まれるかというと、なんと指定した GitHub のリポジトリに Issue として書き込まれる。賢い。</p>
<p><a href="https://github.com/defaultcf/blog/issues">https://github.com/defaultcf/blog/issues</a></p>
<p>これで双方向なウェブサイトになるんじゃないかな?
誰かがマサカリを投げてくれるかもしれないので、私はより一層気を引き締めてブログをやっていきます。</p>JavaScript ってやつでコメント欄増やした。さようなら、2021年2021-12-31T00:00:00+09:002021-12-31T00:00:00+09:00https://default.cf/blog/2021/12/31/goodbye-2021<p>今年は色々生活が変わった1年だった。</p>
<p>まず、東京の企業に就職した。北海道から東京への引っ越しがあった。
その後、COVID-19 の感染者急増もあったので、家に引きこもりながらリモートで働いていた。</p>
<p>稀に30分歩いて秋葉原まで行き、同人誌を漁るなどして気分転換をしていた。
感染状況が収まり始めると、東京の友人たちと肉を食べる会をやった。</p>
<p>仕事はフロントエンドからバックエンド、インフラに至るまでを担当しており、とにかくがむしゃらにやってきたつもり。
入社して最初のクォーターで、最も成長したということで賞を頂戴することができた。
来年も頑張る。</p>
<h2 id="本">本</h2>
<p>今までは大学図書館などで本を読めていた。
就職して会社に本があまり無いので、自分で買うようになった。</p>
<ul>
<li>ハッカーと画家</li>
<li>情熱プログラマー</li>
<li>自在化身体論</li>
<li>Team Geek</li>
<li>UNIXという考え方</li>
<li>人月の神話</li>
<li>ユニコーン企業のひみつ</li>
<li>岩田さん 岩田聡はこんなことを話していた。</li>
<li>WEB+DB Press Vol. 122 ~ 125</li>
</ul>
<p>などなど。</p>
<p>うち半分くらいは既に大学時代に読んだものだけど、めちゃめちゃ影響を受けていたので改めて自分で買って読み直した。
Teem Geek は IT 企業に勤める人みんな読むべき。</p>
<h2 id="ガジェット類">ガジェット類</h2>
<ul>
<li>Ryzen 5600X</li>
<li>B550 Steel Legend</li>
<li>DDR4-3200 8GB x 2</li>
<li>Oculus Quest 2
<ul>
<li>Elite Strap</li>
<li>Quest Link Cable</li>
</ul>
</li>
</ul>
<p>6年以上使ってきた CPU 、マザーボード、メモリを更新した。めちゃめちゃサクサクになったので、3,4年はこれで良さそう。グラボは替えようかな。</p>
<p>そして自分にとって初めての HMD、Oculus Quest 2 を買った。<a href="https://default.cf/blog/2021/12/26/oculus-quest-2/">詳しくは既にブログに書いている</a>。最高。</p>
<p>来年はもっと環境を良くして、VR をもっと楽しみたい。</p>
<hr />
<p>とりま年末に書けるのはここまで。</p>
<p><a href="https://dic.nicovideo.jp/a/%E5%91%A8%E5%A4%AE%E3%82%B5%E3%83%B3%E3%82%B4">みなさま〜(天下無双)</a>、来年もよろしくお願いします。</p>今年は色々生活が変わった1年だった。Oculus Quest 2 を買って VRChat にハマっている2021-12-26T00:00:00+09:002021-12-26T00:00:00+09:00https://default.cf/blog/2021/12/26/oculus-quest-2<p>体験しないと、きっとこの良さは分からない。</p>
<p><img src="/blog/assets/img/2021-12-26-oculus-quest-2/wolf-rest-and-sleep.png" alt="wolf-rest-and-sleep" /></p>
<p>ワールド『<a href="https://vrchat.com/home/world/wrld_fac11e5f-1c73-4436-8936-a70b80961c5a">Rest and Sleep 寝る</a>』にて、私の VR での姿。</p>
<hr />
<p>2021年後半は、VR の話題が尽きなかったように思う。</p>
<ul>
<li>Facebook, inc は Meta, inc(Meta Platforms, inc)という名に変わって、VR 関連に力を入れることを宣言した。
<ul>
<li><a href="https://about.fb.com/ja/news/2021/10/facebok-company-is-now-meta/">https://about.fb.com/ja/news/2021/10/facebok-company-is-now-meta/</a></li>
</ul>
</li>
<li>ANYCOLOR 株式会社はユメノグラフィアの終了を発表した…
<ul>
<li><a href="https://note.com/yume_note1205/n/nb2f04ec86d10">https://note.com/yume_note1205/n/nb2f04ec86d10</a></li>
<li>やっぱまだまだ HMD が普及してないからかな…</li>
</ul>
</li>
<li>今年も Vket が開催された。
<ul>
<li><a href="https://winter2021.vket.com/">https://winter2021.vket.com/</a></li>
</ul>
</li>
<li>SANRIO Virtual Fes が開催され、多くの話題を呼んだ。
<ul>
<li><a href="https://v-fes.sanrio.co.jp/">https://v-fes.sanrio.co.jp/</a></li>
</ul>
</li>
</ul>
<p>特に SANRIO Virtual Fes は、開催後の各種記事を読んで、行かなかったことを後悔した。
“AMOKA が遂に大きな舞台に立った”、”キヌのライブに度肝を抜かれた”、”バーチャル四天王らのパフォーマンスが凄かった”、”初音ミクとキノピオピーのコラボがヤバかった”、”地下5階のクラブがヤバかった”、などなど。</p>
<p><a href="https://vr-lifemagazine.com/sanrio-virtual-fes-in-sanrio-puroland-report/">https://vr-lifemagazine.com/sanrio-virtual-fes-in-sanrio-puroland-report/</a></p>
<p>気になりすぎていろんな記事を漁ったが、やはり実際に体験してみないと分からないことが多すぎた。</p>
<p>大盛況だったことは間違いないようなので、きっとまたこういうイベントはやるだろう。
その時にまたこういう後悔をしたくない。</p>
<p>そう思い、Oculus Quest 2 を買った。ついでに PCVR をやりたかったので CPU を替え、その過程でマザーボードもメモリも替えた。</p>
<hr />
<p>とりあえず VRChat をやっている。
2017年くらいに少し遊んだアカウントがあったので、それでログインしている。 <a href="https://docs.vrchat.com/docs/vrchat-safety-and-trust-system">トラストランク</a> はまだ「Visitor」だった。</p>
<p>「VRChatワールド探検部」というグループの方々が <a href="https://adventar.org/calendars/6950">Advent Calendar</a> でいろんなワールドを紹介しているのを見つけて、それを参考にワールドを巡ったりしている。</p>
<p><a href="https://sites.google.com/view/shaderfes">Shader Fes 2021</a> という、シェーダーをめちゃめちゃ活用した展示物がめちゃめちゃ展示されてるワールドも楽しんでいる。</p>
<p><img src="/blog/assets/img/2021-12-26-oculus-quest-2/groupphoto-at-shaderfes.png" alt="groupphoto-at-shaderfes" /></p>
<hr />
<p>色々遊んでいると、トラストランクが「New user」になった。</p>
<p>早速 booth で可愛らしい3Dモデルを探した。めちゃめちゃある。
その中で一番ピンと来た子を選んだ。名を大神ルゥと言う。</p>
<p><a href="https://booth.pm/ja/items/1845778">https://booth.pm/ja/items/1845778</a></p>
<p>可愛い。</p>
<p>しかし購入した後に気付いたのだが、このモデルは VRC SDK v3 に対応していない(2021年12月26日現在)。
README 通りにアップロードしようとすると、エラーが表示される。</p>
<p>今は非推奨の SDK v2 を使うのもアリではあるが、せっかくなので自分でv3用に修正して、無事アップロードできた。</p>
<p>参考: <a href="https://kurotorimkdocs.gitlab.io/kurotorimemo/010-VR/010_VRChat/Avatars3.0/ToAvatars3/">https://kurotorimkdocs.gitlab.io/kurotorimemo/010-VR/010_VRChat/Avatars3.0/ToAvatars3/</a></p>
<p><img src="/blog/assets/img/2021-12-26-oculus-quest-2/surprised-wolf.png" alt="wolf-with-hamburger" /></p>
<p>可愛い!</p>
<p><img src="/blog/assets/img/2021-12-26-oculus-quest-2/wolf-with-hamburger.png" alt="wolf-with-hamburger" /></p>
<p>可愛い!!
(なんか可愛いので、びっくりしてる顔ばかり撮ってしまう)</p>
<p>ライセンス的に改造が許可されているので、髪と胸の揺れを調整したり、表情の微修正をしたり。
しかし、久々に Unity 触った。 <a href="https://scrapbox.io/defaultcf/Unity%E3%81%AE%E3%83%97%E3%83%AD%E3%82%B8%E3%82%A7%E3%82%AF%E3%83%88%E3%82%92git%E7%AE%A1%E7%90%86%E3%81%99%E3%82%8B">なんとか Git 管理して、いつでも特定のコミットに戻れるようにしている。</a></p>
<p>今後は、Blender も扱えるようになりたいし、ワールドを作ったりしてみたい。
やりたいことだらけで、睡眠時間が削れるのが悩みどころ。</p>
<hr />
<p>こう美少女として VRChat で遊んでいると、かつて自分が VTuber にドハマりして最初の頃に書いた呟きを思い出す。まぁありふれた考えだが。</p>
<blockquote>
<p>VTuberの良さとは、その人の外見・生まれ・性別・年齢など、あらゆる属性を排除した状態で配信を行うことができるという点にある(声すらボイチェンで変えられる)。
https://scrapbox.io/defaultcf/VTuber</p>
</blockquote>
<p>遂に自分も VR で他の誰かになれる日が来たのだと思うと胸アツだ。
今はリアルで知り合った者同士で遊んでいるが、近々 VRChat で知り合って遊ぶという経験をしてみたいものである。</p>
<p>VRChat でお会いしましょう ;)</p>体験しないと、きっとこの良さは分からない。log4j の脆弱性は SELinux で防げるか?2021-12-11T00:00:00+09:002021-12-11T00:00:00+09:00https://default.cf/blog/2021/12/11/selinux-01<p>こんにちは!
この記事は、GIG Advent Calendar の11日目の記事です。遅れてすみません!</p>
<p>log4j の脆弱性の件で各所大変なことになっていますね…
幸い私はその対応に終われることはありませんでしたが…</p>
<p>私が稀に嗜んでいる Minecraft でも、バージョン16以下であれば log4j の脆弱性を抱えているらしいです。
会社ではインフラエンジニアをやっているので、如何に脆弱性による被害を抑えられるかが気になります。</p>
<p>そこでこの記事では log4j と、インフラエンジニア(1年目)から見た脆弱性による被害を最小限に抑える方法について考えます。
1年目なので。。。色々大目に見てください。。。
もし間違いがあったら、是非記事にプルリクを送っていただければと思います。</p>
<h1 id="log4j">log4j</h1>
<p>log4j は、Java のロギングのライブラリらしいです。
今回知ったのですが、このライブラリはいろんなプロダクトに含まれているのですね…</p>
<p>https://logging.apache.org/log4j/2.x/</p>
<h1 id="攻撃">攻撃</h1>
<p>様々な機能を備えており、その中でも Lookup という変数を使える機能が問題のようです。
試しにプライベートネットワーク上に Minecraft サーバを立てて、攻撃できる環境を色々用意してみた結果、確かに実行できそうでした。
手法について詳しく書いたら警察のご厄介になるかも分からないので、これ以上書きません。防ぐ方法を考えるのがメインですし、ね。</p>
<p>https://www.jpcert.or.jp/at/2021/at210050.html</p>
<h1 id="対応策">対応策</h1>
<p>AWS WAF のマネージドルールに、今回の脆弱性を対象とした攻撃を防ぐルールが追加されたようです。
https://dev.classmethod.jp/articles/aws-waf-new-rule-log4jrce/</p>
<p>また SELinux を使って、ターゲットのプロセスがあらかじめ指定したディレクトリ外を読み書きするのを防いだり、
指定したプロセス以外を起動するのを防いだり、外部の LDAP サーバとの通信を防いだりできるんじゃないかなと思っています。</p>
<p>ただし、ポリシーは正しく書かなければ意味が無いですし、SELinux は最後の砦みたいなところがあるので
これに頼りきりにならずに、そもそも log4j の設定を見直したりして脆弱性を塞ぐ努力をするのが最優先でしょう。</p>
<hr />
<p>すみません、今回の記事はここまでです。</p>
<p>攻撃できる環境を用意するだけで土日を使い果たしました…LDAP がよく分からず、LDAP の勉強から始めてました…
SELinux で攻撃の影響を抑えられるような設定とか調べて、また記事書きます、きっと。</p>こんにちは! この記事は、GIG Advent Calendar の11日目の記事です。遅れてすみません!Jekyll で 他の Jekyll から情報を取得する2021-10-24T00:00:00+09:002021-10-24T00:00:00+09:00https://default.cf/blog/2021/10/24/jekyll-fetch-other-jekyll<p>需要が無いかもしれない技術メモ。</p>
<p>Jekyll で作っている2つのサイトがある。</p>
<ul>
<li><a href="https://default.cf/">default.cf</a> ←ポートフォリオサイト</li>
<li><a href="https://default.cf/blog/">default.cf/blog</a> ←ブログ</li>
</ul>
<p>同じドメインでホストしているが、これらは別々のリポジトリで GitHub Pages を使ってビルドされている。そのため、静的ビルド時にリポジトリを跨いで情報を取得・反映するには一手間要る。JavaScript で fetch, parse, render は、SEO の観点からしないものとする。</p>
<p>今回は、ポートフォリオサイト上にブログのリンクを表示したい。
色々考えた末、jekyll-feed で生成される feed.xml を、何らかの方法でポートフォリオの <code class="language-plaintext highlighter-rouge">_data/feed.json</code> に置くことができれば良いとなった。</p>
<p>技術的には次の挑戦が必要だった。</p>
<ul>
<li>XML ファイルを JSON ファイルに変換する</li>
<li>ポートフォリオサイトの GitHub Actions で XML ファイルの取得、JSON ファイルへの変換、コミット</li>
<li>ブログを書いて master にプッシュしたら、ポートフォリオサイトの action が発火され更新される</li>
</ul>
<p>順に説明する。</p>
<h2 id="xml-ファイルを-json-ファイルに変換する">XML ファイルを JSON ファイルに変換する</h2>
<p>xml2json を使って変換することにした。
詳しくは Scrapbox に書いた。</p>
<ul>
<li><a href="https://scrapbox.io/defaultcf/xml2json">scrapbox.io/defaultcf/xml2json</a></li>
<li><a href="https://scrapbox.io/defaultcf/XML_Schema">scrapbox.io/defaultcf/XML_Schema</a></li>
</ul>
<p>XML Schema を頑張って書いて、変換できることを確認した。
ただ一箇所、XML 側を修正しないとどうしても変換できないところがあって、そこは処理前に sed で置換することにした。</p>
<div class="language-bash highlighter-rouge"><div class="highlight"><pre class="highlight"><code><span class="nb">sed</span> <span class="nt">-e</span> <span class="s1">'s/xmlns=/xmlns:atom=/'</span>
</code></pre></div></div>
<h2 id="ポートフォリオサイトの-github-actions-で-xml-ファイルの取得json-ファイルへの変換コミット">ポートフォリオサイトの GitHub Actions で XML ファイルの取得、JSON ファイルへの変換、コミット</h2>
<p>試行錯誤して最終的にこうなった。</p>
<p><code class="language-plaintext highlighter-rouge">.github/workflows/create-blog-links.yml</code></p>
<div class="language-yaml highlighter-rouge"><div class="highlight"><pre class="highlight"><code><span class="na">name</span><span class="pi">:</span> <span class="s">Create blog links</span>
<span class="na">on</span><span class="pi">:</span> <span class="s">workflow_dispatch</span>
<span class="na">jobs</span><span class="pi">:</span>
<span class="na">fetch-and-create</span><span class="pi">:</span>
<span class="na">runs-on</span><span class="pi">:</span> <span class="s">ubuntu-latest</span>
<span class="na">steps</span><span class="pi">:</span>
<span class="pi">-</span> <span class="na">run</span><span class="pi">:</span> <span class="s">sudo apt update && sudo apt install -y libxml-compile-perl libjson-xs-perl</span>
<span class="pi">-</span> <span class="na">uses</span><span class="pi">:</span> <span class="s">actions/checkout@v2</span>
<span class="pi">-</span> <span class="na">run</span><span class="pi">:</span> <span class="pi">|</span>
<span class="s">curl https://default.cf/blog/feed.xml \</span>
<span class="s">| sed -e 's/xmlns=/xmlns:atom=/' \</span>
<span class="s">| xml2json -x - -s feed.xsd \</span>
<span class="s">> _data/feed.json</span>
<span class="pi">-</span> <span class="na">uses</span><span class="pi">:</span> <span class="s">EndBug/add-and-commit@v7</span>
<span class="na">with</span><span class="pi">:</span>
<span class="na">message</span><span class="pi">:</span> <span class="s1">'</span><span class="s">Update</span><span class="nv"> </span><span class="s">feed.json'</span>
<span class="na">committer_name</span><span class="pi">:</span> <span class="s">GitHub Actions</span>
<span class="na">committer_email</span><span class="pi">:</span> <span class="s">41898282+github-actions[bot]@users.noreply.github.com</span>
</code></pre></div></div>
<p>uses を使って checkout と commit は簡単に済ませられる。GitHub Marketplace 様様だ。</p>
<p>手動で workflow を実行して、feed 取得・JSON に変換・コミットが為されることを確認する。</p>
<h2 id="ブログを書いて-master-にプッシュしたらポートフォリオサイトの-action-が発火され更新される">ブログを書いて master にプッシュしたら、ポートフォリオサイトの action が発火され更新される</h2>
<p>GitHub REST API を叩いて、他の workflow を発火することができるらしい。
ブログ側の action をこのように書いた。<del>これでいけるはず…</del></p>
<p>GITHUB_TOKEN の部分は、secrets.GITHUB_TOKEN を使うと失敗する。
<a href="https://docs.github.com/en/actions/security-guides/encrypted-secrets#using-encrypted-secrets-in-a-workflow">https://docs.github.com/en/actions/security-guides/encrypted-secrets#using-encrypted-secrets-in-a-workflow</a></p>
<blockquote>
<p>you can use the secrets context to access secrets you’ve created in your repository</p>
</blockquote>
<p><code class="language-plaintext highlighter-rouge">secrets.GITHUB_TOKEN</code> は、そのアクション1回限りで有効で、且つそのリポジトリにだけ機能するアクセス権限が与えられる。
つまり、他のリポジトリの workflow を発火できない。</p>
<p>ここでのトークンは、personal access token を使うことにした。
repo 全てと、workflow にチェックを入れた。</p>
<p><code class="language-plaintext highlighter-rouge">.github/workflows/kick-portfolio.yml</code></p>
<div class="language-yaml highlighter-rouge"><div class="highlight"><pre class="highlight"><code><span class="na">name</span><span class="pi">:</span> <span class="s">Kick portfolio</span>
<span class="na">on</span><span class="pi">:</span>
<span class="na">push</span><span class="pi">:</span>
<span class="na">branches</span><span class="pi">:</span>
<span class="pi">-</span> <span class="s">master</span>
<span class="na">jobs</span><span class="pi">:</span>
<span class="na">post-api</span><span class="pi">:</span>
<span class="na">runs-on</span><span class="pi">:</span> <span class="s">ubuntu-latest</span>
<span class="na">steps</span><span class="pi">:</span>
<span class="pi">-</span> <span class="na">uses</span><span class="pi">:</span> <span class="s">octokit/request-action@v2.x</span>
<span class="na">with</span><span class="pi">:</span>
<span class="na">route</span><span class="pi">:</span> <span class="s">POST /repos/{owner}/{repo}/actions/workflows/{workflow_id}/dispatches</span>
<span class="na">owner</span><span class="pi">:</span> <span class="s">defaultcf</span>
<span class="na">repo</span><span class="pi">:</span> <span class="s">defaultcf.github.io</span>
<span class="na">workflow_id</span><span class="pi">:</span> <span class="s">create-blog-link.yml</span>
<span class="na">ref</span><span class="pi">:</span> <span class="s">master</span>
<span class="na">env</span><span class="pi">:</span>
<span class="na">GITHUB_TOKEN</span><span class="pi">:</span> <span class="s">${{ secrets.KICK_WORKFLOW_TOKEN }}</span>
</code></pre></div></div>
<hr />
<p>以上。<del>さて、この記事を push したら、workflow がまわるかな…?</del>
<del>結果が出たら、この記事を更新する。</del></p>
<p>GITHUB_TOKEN の部分で引っかかっていた。Personal access token に変更し、再度 push すると、ブログ側の action が動いて、ポートフォリオサイト側の action を発火し、ポートフォリオサイトが更新された!</p>
<p>普段、業務で Bitbucket pipeline を使っているので、GitHub Actions は久々だったが、やっぱ GitHub Actions も良いな…フックが充実している。</p>需要が無いかもしれない技術メモ。鈴原るるの卒業にあたって、あるオタクの呟き2021-07-01T01:00:00+09:002021-07-01T01:00:00+09:00https://default.cf/blog/2021/07/01/lulu-suzuhara<p>鈴原るるが、2021年6月30日に卒業する。
以下、ただのオタクの自分語り。</p>
<hr />
<p>鈴原を知ったのは、2020年1月頃、ニコ生で深夜やっていた、 Virtual To Live の最終公演の一部再放送。鈴原はほかの VTuber と共に「林檎もぎれビーム!」を歌っていた。完璧なアイドルステップを踏む鈴原が非常に気になったのを覚えている。</p>
<p>その頃には鈴原がデビューして1年近く経っており、既に大量のアーカイブ動画があったが、気になって最初の方からずっと観ていった。作業しながら観、深夜眠れない時に観…</p>
<p>そこからにじさんじの他の VTuber の配信を観るようになり、やがて VTuber 全体に対して深い関心を持つようになった。
それでも、鈴原の配信はほぼ欠かさず観ていた。
レトロゲーでも、イマドキのゲームでも、本当に楽しそうに遊んでいる。非常に脳筋なところがあるので、片っ端から手段を試す。そして全く諦めない。その姿が本当に好き。
雑談配信も好き。「こんなお酒飲んでる」というのを、鈴原らしい絵で示してくれるのが個人的にめちゃめちゃ好き。深夜の語り弾きが好き。
鈴原とその父、姉とのコラボ配信はなかなか革新的だったように思う。</p>
<p>他のライバーとのコラボ、3D配信、ラジオなどなど、多方面に活躍する鈴原が好き。</p>
<p>そうした鈴原が起点となって、自分もいろんなことを好きになることができた。</p>
<hr />
<p>そんな鈴原るるが、今日を以って VTuber を辞める。
“推しは推せる時に推せ” という言葉の重みを、身を以って知った。</p>
<p><img src="/blog/assets/img/suzuhara-membership.png" alt="suzuhara membership" /></p>
<p>メンバーシップ、1年3ヶ月20日目。もっと早くから出会えたら良かった。</p>
<iframe width="560" height="315" src="https://www.youtube-nocookie.com/embed/-d8NPJ8ShfI?rel=0" title="YouTube video player" frameborder="0" allow="accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture" allowfullscreen=""></iframe>
<p>最後の配信では、同時視聴者数18万人を超え、それでもほぼいつもと変わらない口調で思い出を語っていた。本当にメンタルが強い。
これが最後の配信とは思えないし、思いたくない。
過去の衣装お披露目から始まり、さいねママによる未公開デザインのお披露目が行われた。
本当にかわいらしい、まさに鈴原にぴったりの衣装ばかりだった。
それは今後の配信で使われたかもしれないもので、いつか3D配信での衣装になるかもしれないものだった。そんな未来が来たらどれほど良かったことか。</p>
<p>引退理由を明かしてくれた。深くここでは書かないが、一ファンとして本当にやるせなく、悔しく思う。
それでも、鈴原は VTuber が好きで、他のライバーが好きで、ファンが好きだと言ってくれた。
鈴原は自身の配信に自信を持てなかったというが、徐々に自分自身のことが好きになっていったと言うし、幸せだったと言う。ファンとしてもそれは本当に嬉しく、こちらも本当に幸せだった。</p>
<hr />
<p>そうして、7月1日0時を少し過ぎ、彼女は配信を終えた。最後まで鈴原るるたっぷりだった。
今後、ことあるごとに鈴原を思い出すんだろうな…そして徐々に思い出す頻度は少なくなっていくんだろうけど、でも絶対に忘れない。</p>
<p>本当に多くの幸せをありがとう。</p>
<p>ただただ、彼女の今後の人生、健康で幸多いことを願う。</p>鈴原るるが、2021年6月30日に卒業する。 以下、ただのオタクの自分語り。Hi defaultcf, bye i544c2021-04-24T21:52:00+09:002021-04-24T21:52:00+09:00https://default.cf/blog/2021/04/24/change-user-name<p>色々あって、ユーザ名を変更する運びとなりました。</p>
<h2 id="引っ越し">引っ越し</h2>
<p>働くために、東京に引っ越しました。
COVID-19 によるパンデミックの最中ですが、他に選択肢がありませんでした。</p>
<p>歩いて30分ほどで秋葉原に行けるところで、なかなか良いです。</p>
<h2 id="就職">就職</h2>
<p>ご縁があって東京のベンチャー企業で働いています。
インフラエンジニアとしてサーバの保守や CI/CD の整備の他、バックエンドやフロントエンドのコードを修正することもあり、今までやってきたことを活かすことができています。</p>
<p>知見が貯まってきたら、外部に発信していきたいなと考えています。</p>
<h2 id="ユーザ名変更">ユーザ名変更</h2>
<p>大学時代は <code class="language-plaintext highlighter-rouge">Isaac</code> や <code class="language-plaintext highlighter-rouge">i544c</code> などと名乗っていました。実は高校の頃から使っていたユーザ名で、なんと9年近くも使っていました。
ただ、Twitter などで既に他のユーザが <code class="language-plaintext highlighter-rouge">i544c</code> を使用しているなど、各種サービスでユーザ名を統一できておらず、モヤモヤしていました。</p>
<p>そんな中、たまたま <a href="https://freenom.com/">Freenom</a> で <code class="language-plaintext highlighter-rouge">default.cf</code> というドメインが取れることに気付きました。ユーザ名を <code class="language-plaintext highlighter-rouge">defaultcf</code> にすれば(本来の意味で)ユニークそうだし、社会人になるしで、この度改名することとしました。</p>
<p>ポートフォリオも一新しました。 <a href="https://default.cf/">https://default.cf/</a></p>
<p>i544c.me を default.cf にリダイレクトし、 blog.i544c.me を default.cf/blog 下にリダイレクトするようにしました。同じ GitHub Pages のコンテンツなのにブログだけサブドメインで運用していて気持ち悪かったので、変更する良い機会でした。</p>
<h3 id="freenom">Freenom</h3>
<p>…このブログを書いている今になって、 Freenom の無料ドメインの規約が気になっています。
ドメインの所有者ではなく、あくまでユーザで、 Freenom によって取り消されるかも分からない。ネット上ではドメインが使えなくなったという話がちらほら…</p>
<p>金を払うべきでした…
既に無料ドメインで取ってしまったので、1年経ったらそれ以降は有料で使おうと思います。</p>色々あって、ユーザ名を変更する運びとなりました。さようなら、2020年2020-12-31T20:52:00+09:002020-12-31T20:52:00+09:00https://default.cf/blog/2020/12/31/goodbye-2020<p>2020年は酷かった。</p>
<p>まず、COVID-19によるパンデミックが、ずっと世間に暗い影を落としていた。
私の就活もあった。難なく進むかな、などと軽く考えていたら、散々な結果が続いた。
そして、VTuber文化に救われた。</p>
<h2 id="就活">就活</h2>
<p>色んな会社を受けたが、落ち続けた。自分のせいなのか、COVID-19のせいなのか分からず、陰鬱とした日々だった。
それでも社会人になることを諦められず、細々と就活を続けた結果、なんとかベンチャー企業から内定を頂戴した。</p>
<p>今はこれ以上書く気になれない。</p>
<h2 id="vtuber">VTuber</h2>
<p>VTuberの存在自体2018年から知っていたが、2020年3月あたりからドハマりした。
特にホロライブ3,4期生にハマって、わための歌、あさココを毎朝見ていた。
VTuberという存在についての思考も楽しく、よく考察記事を漁ってもいた。</p>
<p>適当にまとめたページを書いたりもした…
<a href="https://scrapbox.io/i544c/VTuber">i544c/VTuber</a></p>
<h2 id="プログラミング">プログラミング</h2>
<p>今までスクリプト言語を中心に書いてきたが、2020年は型の便利さを改めて学んだ。TypeScriptを書いたり、Elixirを学んだりした。
VTuberに寄与できたらと、幾つか簡単なものを作ったりもした。</p>
<h4 id="vgif">vGIF</h4>
<p><a href="https://github.com/i544c/vgif">github.com/i544c/vgif</a></p>
<p>VTuberのAnimated GIFを共有できる、ウェブアプリケーション。
Rails製。デプロイはHerokuにして、画像のホストはS3にした。</p>
<h4 id="youtube-sticky-live-chat">YouTube Sticky Live Chat</h4>
<p><a href="https://greasyfork.org/ja/scripts/402617-youtube-sticky-live-chat">greasyfork.org/ja/scripts/402617-youtube-sticky-live-chat</a></p>
<p>YouTubeのライブチャットで、放送主かモデレータのコメントを一番上に固定して表示する、UserScript。
(その後、YouTubeは公式に投稿主のコメントをトップに固定できる機能をリリースした)</p>
<h4 id="nico-excluder">Nico Excluder</h4>
<p><a href="https://greasyfork.org/ja/scripts/405548-nico-excluder">greasyfork.org/ja/scripts/405548-nico-excluder</a></p>
<p>ニコニコ動画のランキングページから、指定したユーザの投稿した動画を非表示にする、UserScript。
珍しくちゃんとクラス使って綺麗に書いたなぁ…</p>
<h4 id="大神ミオ通知bot">大神ミオ通知bot</h4>
<p><a href="https://twitter.com/mio_bot">twitter.com/mio_bot</a></p>
<p>年の瀬に大神ミオちゃんのTwitterアカウントが凍結してしまった。大神ミオちゃんはYouTubeのライブで、公開を2年ほど先に指定した枠を立てて、そこのライブチャットでファンたちと対話している。
しかし、ライブチャットでは過去のコメントが流れてしまって、大神ミオちゃんの発言が遡れない。</p>
<p>なので、ライブチャットを監視して、大神ミオちゃんの発言が来たらTwitterで呟くbotを作った。
今度、技術記事を書こうかなと思っている。</p>
<h4 id="f-corps">f○○○ corps</h4>
<p><a href="https://gist.github.com/i544c/1ae779e494cdc0cf5d2f95a1b01be278">i544c/fuck_corps.user.js</a>
私を落とした企業の名称を「クソ企業」に置換する、ユーザスクリプト。これで大体のウェブページで、不快な名称を目にすることがなくなる(SPAなど動的にウェブページを書き換えているサイトでは機能しない)。</p>
<h2 id="おわり">おわり</h2>
<p>2020年は酷かった。でも、VTuberに救われた。
来年はさっさと卒業し、東京に引っ越して、ソフトウェアエンジニアとして生きる予定。</p>2020年は酷かった。Hello Gemini2020-08-31T16:52:00+09:002020-08-31T16:52:00+09:00https://default.cf/blog/2020/08/31/gemini<p>Geminiというものに出会った。
双子座という意味のそれではなく、昨今の複雑化したウェブを憂いて作り出された、シンプルなインターネットプロトコルを指す。</p>
<p>https://gemini.circumlunar.space/</p>
<p>Geminiはウェブと似ているようで違う。TLSによる通信しか許されず、セキュアだ。</p>
<p>またGeminiには、クライアントで装飾するためのCSSも無く、またクライアントでインタラクティブなことができるJavaScriptも無い。
やり取りするのはただのテキストファイルで、それはMarkdownに似たシンプルな書式だ。</p>
<p>インラインでの画像埋め込みすら出来ず、本当に文字だけを伝えられる。
古い古いウェブを体感させてくれるようで、なんだかセンチメンタルな気分になる。(その時代には生まれていないのだが)</p>
<p>試しに自分もGeminiでの配信を始めてみた。
https://gemini.circumlunar.space/clients.html にあるクライアントを使うことで閲覧できる。</p>
<p>gemini://gemini.i544c.me</p>
<p>とりあえず、感情が昂ぶった時にそこで吐き出している。
今までこのブログに書いてきたヲタクな話を、これからはこのGeminiで配信していこうと思う。</p>Geminiというものに出会った。 双子座という意味のそれではなく、昨今の複雑化したウェブを憂いて作り出された、シンプルなインターネットプロトコルを指す。