iimon TECH BLOG

https://tech.iimon.co.jp/

iimonエンジニアが得られた経験や知識を共有して世の中をイイモンにしていくためのブログです

フィード

記事のアイキャッチ画像
Orvalを使ってOpenAPI SchemaからAPIクライアントを自動生成する
iimon TECH BLOG
■はじめに ■環境 ■Orvalとは何か ■Orvalを使うと何が変わるか ◆手書きの場合 ◆Orvalを使う場合 ■ハンズオン ◆今回作るもの ◆ディレクトリ構成を作る ◆バックエンドのセットアップ ◆Djangoプロジェクトを作成する ◆モデルを定義する ◆スキーマを ModelSchema で定義する ◆APIを定義する ◆動作確認とスキーマのファイル出力 ◆フロントエンドのセットアップ ◆Orvalの設定ファイルを書く ◆モデルのフィールド変更に追従する ■まとめ ■はじめに こんにちは! iimonでエンジニアをしています「しらみず」です。 現在、新規サービス開発をする中で、フロント…
3日前
記事のアイキャッチ画像
AIってTypeScriptをどういう風に感じてるのだろう
iimon TECH BLOG
はじめに Branded Types Effect TS まとめ さいごに 参考 はじめに こんにちは!iimonでエンジニアをしているひがです。 最近AIでソースコード生成を利用する場面も当たり前になってきましたが、その中でどんなコードを書くとAIはどんな反応をするのだろう??という疑問がふつふつと湧いてきまして、いてもたってもいられなくなってきました。 ということで、今回はTypeScriptの書き方でAIにどのような影響があるかを簡単に見ていこうと思います!とはいえ TypeScript の型システムはとても奥が深く、細かい内容を見ていくととても膨大になってしまうため、今回は Brand…
8日前
記事のアイキャッチ画像
【React】よく使うHooks3選をわかりやすく整理してみた
iimon TECH BLOG
はじめに そもそもReact Hooksってなに? useState - 状態を管理する 概要 基本的な使い方 コード例 よくある使い方いろいろ 注意点 useEffect - 副作用を実行する 概要 基本的な使い方 依存配列のパターン コード例 APIからデータを取得する クリーンアップが必要な例 注意点 useContext - コンポーネント間でデータを共有する 概要 propsのバケツリレー問題 コード例 注意点 Hooks一覧まとめ まとめ 参考文献 はじめに こんにちは!株式会社iimonエンジニアのクリスチャンです! 最近、暖かくなってきてアイスコーヒーが美味しい季節になってきま…
10日前
記事のアイキャッチ画像
Claude Code on the Webが個人的に良かった話と今後の期待
iimon TECH BLOG
はじめに Claude Code on the Webとは 使い方 基本的なセットアップ 1. claude.ai/code にアクセス 2. GitHubアカウントを接続 3. クラウド環境の設定 4. リポジトリを選んでタスクを入力 メリット・デメリット メリット ローカル環境が完全に不要 ウェブとターミナル間でタスクを移動 Teleport でローカルに引き継げる 権限承認が不要 デメリット ローカルのリソース(資源)が使えない ブランチ名を自由に設定できない(claude/始まりになる) 編集者がClaudeになる クラウド環境のスペックが非公開 今後の期待 セッション途中での環境・ブ…
15日前
記事のアイキャッチ画像
関数のカリー化について
iimon TECH BLOG
はじめに カリー化とは 部分適用 再利用性の向上 ルールと処理の分離 関数合成について カリー化と関数型言語 純粋関数と参照透過性 純粋関数型言語であるHaskell まとめ 参考文献・記事 はじめに こんにちは。iimonでエンジニアをしている金庭です。 今回は、複数の引数を取る関数を、単一引数をとる関数の連続呼び出しに置き換えるという、カリー化について調べたのでご紹介します。 カリー化とは カリー化(Currying)とは、一言でまとめてしまえば複数の引数をとる関数を、単一引数をとる関数の連続呼び出しに変形させることです。はい、前段で述べたことの全くの繰り返しになってしまいましたが、これが…
1ヶ月前
記事のアイキャッチ画像
QR決済とICカード決済の技術の違い
iimon TECH BLOG
普段お店などで決済する時に使用しているQR決済が、 どういう仕組みで動いているのか気になり今回調べてみることにしました。 CPMやMPMといった方式の違い、サーバーとの通信、オフラインの仕組みなど、色々と発見がありました。 また同じ決済でも、Suicaは改札で一瞬で処理が終わっていて、 こんなに処理速度が違うのはなぜなのかというのも気になり 今回は両方の仕組みを比較して、どのような設計の違いがあるのかをまとめてみました。 1. QR決済の仕組み 基本構造 QRコード決済は、インターネット経由でサーバーと通信する ことを前提とした決済方式です。 残高情報や決済履歴はすべてサーバー側で管理されてい…
1ヶ月前
記事のアイキャッチ画像
Knipでプロジェクトの不要コードを検出してみた
iimon TECH BLOG
はじめに こんにちは、保田です。 普段の業務ではClaude Codeを活用した開発を行っています。 AIコーディングによってコードの生成スピードは上がる一方で、不要なコードの蓄積を防ぐことが重要になっていると感じています。 使われなくなった関数やexportされたままの型定義、package.jsonに残った未使用の依存関係など、動作には影響しないものの放置するとコードベースが徐々に肥大化していってしまいます。 こうした不要コードをプロジェクト全体から検出・削除したいと思い、今回はKnipを試してみたので、その機能と使い方を紹介します。 https://knip.dev/ 不要コードが蓄積す…
1ヶ月前
記事のアイキャッチ画像
電子書籍リーダーで快適に読みたい
iimon TECH BLOG
こんにちは、木村です。(非常に遅ればせながら)本年もよろしくお願いいたします。 さて、入社してから2年が経とうとしています。よりスキルアップしていきたいなと思うこの頃ですが、勉強の一つとして技術書を幅広く読みたいなーと思う一方、なかなか時間がとれなかったり集中できなかったり… そんななか、私は技術書にかかわらず本を読むのによく Kindle を使用します。本を嵩張らず持ち運べるっていうのはいいですよね。最近購入した本は PDF 形式だったため、直接 Kindle に入れて読むことができたのですが、ふと「Kindle で読む通常の本ってなんで文字の大きさが変更できるの?」と思いました。 PDF …
1ヶ月前
記事のアイキャッチ画像
React Scanで再レンダーを改善してみた
iimon TECH BLOG
はじめに 使用技術 React Scanとは React Scanの導入 React Scan使ってみる React Scanの分析 分析結果から改善 JavaScript/React Hooks AntdIconの改善 その他のAntdのコンポーネントの改善 改善結果 useCallback + React.memoでチェックボックスの改善 改善結果 子コンポーネントのメモ化 改善結果 最後に はじめに こんにちは、iimonエンジニアのみやこしです!今回は、Reactアプリのパフォーマンス改善に役立つツール React Scan を使って、実際の業務で発生したテーブルリストで「チェックボッ…
1ヶ月前
記事のアイキャッチ画像
呪術に触れてみた
iimon TECH BLOG
こんにちは、kogureです。 勉強会のお題を考えているときにEMから今、巷で流行っているJujutsuどう?とお勧めされたので触ってみました! そもそもJujutsuってなんなんでしょうか? 公式のreadme> Introductionを確認してみましょう github.com Git互換の新しいVCSで既存のGitツールやGitHub等とそのまま連携可能 作業コピーへの変更が自動的にコミットとして記録される 操作ログと元に戻し機能:すべての操作が記録され、ミスを簡単に取り消せる etc... 原文が英語なので翻訳しながら確認したのでわかっていない部分もありますが、 Gitよりあまり操作を…
1ヶ月前
記事のアイキャッチ画像
エンジニア&デザイナーのためのフォント入門
iimon TECH BLOG
皆様ごきげんよう。タクシです。 最近、花粉症をこの世から消す方法と同じぐらい私はフォントについて調べています。 開いたWebサイトがどのフォントを使っているかをデベロッパーツールで確認するのが習慣です。1人でフォント当てクイズをしたりもします。(サイズとかウェイトとか当たるとなんか嬉しい) 当たり前ですがフォントってたくさんあるんです。漠然とフォントに想いを馳せていたら気になって寝不足気味になってきた気がするのでフォントの始まりから調べてみました。 フォントとは? もともとフォントは「同じサイズ・同じスタイルの文字のセット」を指す言葉でした。活版印刷の時代には、たとえば「Garamond の …
2ヶ月前
記事のアイキャッチ画像
Macのアクティビティモニタを理解する
iimon TECH BLOG
はじめに 株式会社iimonエンジニアのかとうです! Macのファンがうるさくなったり、動きが遅くなったり固まったりしたときに、私はまずアクティビティモニタを確認します💧 不要なプロセスの終了にしか使用したことがなかったので、他にもどのように使えるか調べてみました。 本記事では、アクティビティモニタのCPU・メモリ・エネルギータブに表示される項目の意味と見方について解説します☘️ アクティビティモニタとは macOSには アクティビティモニタ というシステムモニタリングツールが最初から入っていて、Macで実行しているプログラム(プロセス)が使用しているメモリの容量やCPU時間などを知ることがで…
2ヶ月前
記事のアイキャッチ画像
「なぜダメか」で学ぶクラス設計
iimon TECH BLOG
導入 こんにちは!iimonで「入力速いもん」の開発を担当しているなかむ〜です! 弊社のメイン製品である「入力速いもん」は、リリースから時間が経っていることもあり、現在はレガシーな設計から「新しく保守しやすい設計」への移行を絶賛進めている最中です。 移行後の新しい設計を見て「すごくいいな!」と直感的に感動したのですが、一方で「自分は何をもって『良い設計』だと判断しているのか?」がいまいち言語化できていないことにも気づきました。 そこで今回は、良い設計・悪い設計を自分なりに整理し、言語化する良い機会だと思いこのテーマを選びました。 「こう書くと破綻する」というパターンを知ることで、日々のコードレ…
2ヶ月前
記事のアイキャッチ画像
型に縛られず、型を守る。忘れがちな「ジェネリクス」を改めて整理して武器にする
iimon TECH BLOG
こんにちは。iimonでエンジニアをしているhayashiと申します。 普段は主に拡張機能を開発しております。 今回はジェネリクスについて何となく分かったつもりではいたけれど、 忘れがちという事に気付きまして、ちゃんとアウトプットしてみようと思います。 ジェネリクスとは ジェネリクスは関数やクラスを、ジェネリクスは「型を引数として受け取る」仕組みのことです。 なぜジェネリクスが必要なのか 例えば以下のような配列の一番最初の要素を返す関数があります。 想定としては、配列が何の型の配列であれ0番目を返したいだけとします。 この関数は現状、宣言したnumberしか扱えません。 なので以下のようにst…
2ヶ月前
記事のアイキャッチ画像
Chrome拡張機能のE2Eテスト、PlaywrightとPuppeteerどっちを選ぶ?調べて比較してみた
iimon TECH BLOG
目次 1. はじめに 2. PlaywrightとPuppeteerの関係性 3. Chrome拡張のテスト観点での技術比較 4. 公式ドキュメント・情報量の比較 5. CI/CDへの組み込みやすさ 6. 結論:どちらを選ぶか 7. おわりに 1. はじめに こんにちは!iimonでフロントエンドエンジニアをしている「奥島」です! Chrome拡張機能のE2Eテスト自動化を調べていると、ツール選定で必ず出てくるのが PlaywrightとPuppeteer の2択が多い印象です。 「Playwright or Puppeteer(パペティア)」の比較記事は世の中にたくさんありますが、一般的なW…
2ヶ月前
記事のアイキャッチ画像
Chromeってどんなふうにうごいているの?
iimon TECH BLOG
はじめに Chromeのアーキテクチャはマルチプロセス?!! マルチプロセスを採用することの意味 マルチプロセスを採用することの課題とその対応 まとめ さいごに はじめに こんにちは!iimonでエンジニアをしているひがです! 先日アドベントカレンダー2025でV8 JavaScript engineに関する記事を投稿させてもらいました! https://tech.iimon.co.jp/entry/2025/12/05 (月日の流れがめちゃくちゃ早く感じます、投稿からもう2ヶ月経ちます、、1月もあっという間に過ぎ去ってしまいました) 上記の記事でも説明していますが、V8 JavaScript…
2ヶ月前
記事のアイキャッチ画像
AI駆動開発の新常識「SDD」- Spec Kitとcc-sddを実際に使って感じたこと
iimon TECH BLOG
1. はじめに こんにちは!株式会社iimonでエンジニアをしている「みよちゃん」です! いや〜来てますねAIの波。開発現場でもAIは「あると便利なもの」から「ないと困るもの」に変化しつつありますよね。この記事もAIに添削してもらいながら執筆しています。 弊社でも、AIを活用するための試行錯誤を日々行なっています。全エンジニアにClaude CodeのMax Planを配布しており、日々活用法を共有し、開発効率の向上を目指しています! AIを使った開発手法が主流になる中、最近注目を集めているのがSpec-Driven Development(仕様駆動開発 / SDD)という手法です。 私は、最…
2ヶ月前
記事のアイキャッチ画像
Chrome拡張機能開発で意識したいセキュリティ対策(Manifest V3)
iimon TECH BLOG
はじめに 前提: Content ScriptとService Workerの違い 公式ドキュメントに基づくセキュリティ対策 Content Scriptの信頼性が低い理由 1. Content ScriptがアクセスするDOMの信頼性が低い 2. Webページと同じレンダラプロセスで実行される 対策 1. Content Scriptからのメッセージは検証しサニタイズする 脆弱な実装例 安全な実装例 補足: 外部との通信(externally_connectable) 2. Content Scriptから実行可能なアクションの範囲を制限する 脆弱な実装例 安全な実装例 3. 機密情報はCo…
3ヶ月前
記事のアイキャッチ画像
TypeScriptの型システム、実はチューリング完全って知ってましたか?
iimon TECH BLOG
はじめに 基礎パーツ作成 タプルのlengthで数値を取得 タプルを生成するユーティリティ タプルの結合 足し算の実装 引き算の実装 注意点 再帰の深さ 整数限定 チューリング完全について 応用編 掛け算 比較 まとめ 最後に 参考 はじめに こんにちは!株式会社iimonでフロントエンジニアをしているあめくです! iimonではフロントエンドにTypeScriptを採用しており、型を用いた開発を行ってます。 私自身、以前はPHPを使っていたこともあり、最初は「型...扱うのが大変そうだな...」と思っていました。 しかし最近はClaudeを使って開発していると、いい感じに型を設定してくれて「…
3ヶ月前
記事のアイキャッチ画像
チーム目標に合わせてJestカバレッジを"狙い撃ち"計測する方法
iimon TECH BLOG
こんにちは!iimonでフロントエンドを担当しております、まつむらです! 私たちのチームでは開発中のプロダクトにおいてテストコードが不足していたため、カバレッジを指標としてテストを増やす取り組みを行っていました。 もちろんカバレッジを上げることが本質的なテスト品質が向上するわけではない事は理解していましたが、テストの量が不足していたためこの様なカバレッジをみんなで意識して増やそうという取り組みを行っていました。 最初はGoogleが提唱するテストカバレッジの指標(60%/75%/90%)を参考に、まず60%を目指してLines Coverageを伸ばすことに集中していました。 ただ、60%が見…
3ヶ月前
記事のアイキャッチ画像
積読解消プロジェクト「リファクタリング(第2版)既存のコードを安全に改善する」Part2
iimon TECH BLOG
1. はじめに 2. 6章 リファクタリングはじめの一歩 パラメータオブジェクトの導入 3. 7章 カプセル化 レコードのカプセル化 4. 8章 特性の移動 5. 9章 データの再編成 6. 10章 条件記述の単純化 7. 11章 APIのリファクタリング コマンドにおける関数の置き換え 8. 12章 継承の取り扱い メソッド、フィールド、コンストラクタの引き上げ メソッド、フィールドの押し下げ スーパークラスの抽出 サブクラスの削除 9. まとめ 参考記事 本のリンク 1. はじめに 株式会社iimonでエンジニアをしている齋藤です。 以前、「リファクタリング(第2版)既存のコードを安全に改…
3ヶ月前
記事のアイキャッチ画像
MySQLのカラム追加や削除はなぜ速くなったのか?
iimon TECH BLOG
はじめに みなさま、本年もよろしくお願いいたします。 現在のMySQLは本番環境でもカラム追加も懸念すべきことも少なくなり、ALTER TABLE ... ADD COLUMN を実行すれば、テーブルのサイズやレコード数に関係なく一瞬で完了するようになりました。 以前は本番環境でカラムを1つ追加するだけなのに、数時間掛かることもあったため メンテナンス画面(サービス停止)にして対応することもありました。 この記事では、MySQLのDDL(スキーマ変更)の技術の進歩を、MySQL5.5系から現在までまとめてみようと思います ※ この記事ではInnoDBを前提としています。 ※ Amazon Au…
3ヶ月前
記事のアイキャッチ画像
JWT認証の仕組みについて調べてみた
iimon TECH BLOG
■はじめに ■認証とは? ■JWT認証とは ■セッション認証方式 ◆処理フロー ◆セッション認証方式の課題点 ■JWTの構造 ■HMAC(Hash-based Message Authentication Code)とは ■アクセストークンとリフレッシュトークン ■JWTを使った認証フローを確認してみる ■悪者がJWTを盗んで偽造した場合に検知される仕組み ■まとめ ■参考記事 ■はじめに 株式会社iimonでエンジニアをしている「白水(しらみず)」です。 みなさま、明けましておめでとうございます。 本年もよろしくお願いいたします。 新規サービスの開発にあたり認証周りをどうするか考えていたので…
3ヶ月前
記事のアイキャッチ画像
React 19.2で追加された<Activity>コンポーネントについて
iimon TECH BLOG
はじめに こんにちは、保田です。本記事はiimonアドベントカレンダー25日目の記事となります。 試験的機能として開発されていた<Activity>コンポーネントが、2025年10月にリリースされたReact 19.2で正式に導入されました。 普段の業務で使えるものなのか気になったので、今回調べてみることにしました。 https://ja.react.dev/reference/react/Activity タブ切り替えで状態が消える問題 Reactでタブを切り替えるとき、よく使われるのが条件付きレンダリングです。 import { useState } from 'react'; const…
4ヶ月前
記事のアイキャッチ画像
これぞ拡張機能の真髄!chrome.webRequest APIについてまとめてみた
iimon TECH BLOG
こんにちは。iimonでエンジニアをしているhayashiと申します。 普段は主に拡張機能を開発しております。 本記事はiimon Advent Calendar 2025 24日目の記事となります! 今回はこれぞ拡張機能の真髄って個人的に思ったchrome.webRequest APIについて解説したいと思います! chrome.webRequest APIとは chrome.webRequest APIとはChrome Extensions(拡張機能)で用意されているAPIです。 このAPIはトラフィックをモニタリングして分析し、送信中のリクエストを傍受、ブロック、変更することが出来るAP…
4ヶ月前
記事のアイキャッチ画像
不気味の谷から考える:違和感とユーザー体験
iimon TECH BLOG
はじめに 不気味の谷 AIにおける不気味の谷 動画生成AI AIのハルシネーション 開発と不気味の谷の関係 不気味の谷を避ける配慮 さいごに 参考 はじめに 本記事はiimon Advent Calendar 2025 23日目の記事となります! みなさまごきげんいかがでしょうか。 株式会社iimonでエンジニアをしているtakuです。 寒い日も多くなり冬らしくなってきましたね。 さて、今回はアドベントカレンダー23日目ということで、ずっと気になっていた"感覚"について少し掘り下げてみました。 最近ではAI活用が多くの領域で推進されており、弊社もまさに取り組んでいる真っ只中です。 私は小さい頃…
4ヶ月前
記事のアイキャッチ画像
Claude Codeサブエージェントハンズオン
iimon TECH BLOG
はじめに 本記事はiimonアドベントカレンダー22日目の記事となります。 こんにちは、kogureです。 あっという間に12月ですね、去年にアドベントカレンダーを書いたのが昨日のことのようです。 こうやってあっという間に歳をとっていくのですね。怖いですね。 今回はClaude Codeのサブエージェントをハンズオンで触ってみたいと思います。 というのもチームメンバーにAI関連の情報をマメにキャッチアップしている方がいてその方からサブエージェントというものがあるんだよっていう話を聞いて興味が湧いてきました。 ちょうどアドベントカレンダーの時期と被ったのでせっかく触ってみるならまとめてみようと思…
4ヶ月前
記事のアイキャッチ画像
最初から完璧は目指すな──初めて設計するあなたへ伝えたい、TypeScript設計の最低ライン
iimon TECH BLOG
初めて0→1設計を任された人向けに、TypeScriptを例に「壊れにくく変更に強い設計」を解説。依存方向の整理、副作用の隔離、テストファースト、仕様変更に強い型設計など、品質とスピードを両立する最低限の設計ポイントを紹介する記事です。
4ヶ月前
記事のアイキャッチ画像
SwiftUIで「推し活カレンダー」アプリを作ってみた
iimon TECH BLOG
この記事はiimon Advent Calendar 2025 20日目の記事となります! はじめに 開発環境 完成したアプリ 開発の流れ 1. まずはシンプルなスケジュールアプリから @Stateと@Bindingの使い分け 2. カレンダーUIを自作 日付セルのデザイン 3. カテゴリをenumで管理 4. シートで入力画面を表示 5. 年別集計機能 6. TabViewで画面を分ける 今回躓いたポイント ✔︎Task という名前は避けた方がいい ✔︎Int型の入力フィールド 今後やりたいこと まとめ 最後に 参考 はじめに こんにちは!新卒エンジニアのつかちゃんです!今回は私の趣味を交え…
4ヶ月前
記事のアイキャッチ画像
MutationObserverを理解する
iimon TECH BLOG
MutationObserverとは 処理ステップと実装方法 オプションの設定 childList subtree attributes attributeFilter MutationRecordのプロパティ 無限ループの罠 廃止されたMutationEvent まとめ 参考記事 こんにちは。 iimonアドベントカレンダー19日目の記事を担当させていただきます、株式会社iimonのねにーです。 ついこの間アドベントカレンダーを書いたばかりのような気もするのですが、 早いもので気がつけば今年ももう12月です。 今年は所属プロダクトが変わり、またAIのインパクトと恩恵を目の当たりにしたりと、浅…
4ヶ月前