line-notification-message
Reference for LINE Notification Messages — phone-number-based messaging to non-friends, template type (premade layouts) and flexible type (custom Flex Message), delivery completion webhooks, user consent flow, SMS authentication, and billing. Use when the user asks to "send a notification message via phone number", "hash a phone number for PNP", "handle delivery completion webhook", "set up template or flexible notification", "check notification message count", or mentions LINE notification messages, PNP push, phone-number-based delivery, hashed phone number, notification template, delivery completion event, consent states, or SMS authentication for notifications. Always use this skill whenever the user mentions LINE notification messages, PNP, or phone-based LINE messaging to non-friends, even if they don't explicitly say "notification message".
下記のコマンドをコピーしてターミナル(Mac/Linux)または PowerShell(Windows)に貼り付けてください。 ダウンロード → 解凍 → 配置まで全自動。
mkdir -p ~/.claude/skills && cd ~/.claude/skills && curl -L -o line-notification-message.zip https://jpskill.com/download/8832.zip && unzip -o line-notification-message.zip && rm line-notification-message.zip
$d = "$env:USERPROFILE\.claude\skills"; ni -Force -ItemType Directory $d | Out-Null; iwr https://jpskill.com/download/8832.zip -OutFile "$d\line-notification-message.zip"; Expand-Archive "$d\line-notification-message.zip" -DestinationPath $d -Force; ri "$d\line-notification-message.zip"
完了後、Claude Code を再起動 → 普通に「動画プロンプト作って」のように話しかけるだけで自動発動します。
💾 手動でダウンロードしたい(コマンドが難しい人向け)
- 1. 下の青いボタンを押して
line-notification-message.zipをダウンロード - 2. ZIPファイルをダブルクリックで解凍 →
line-notification-messageフォルダができる - 3. そのフォルダを
C:\Users\あなたの名前\.claude\skills\(Win)または~/.claude/skills/(Mac)へ移動 - 4. Claude Code を再起動
⚠️ ダウンロード・利用は自己責任でお願いします。当サイトは内容・動作・安全性について責任を負いません。
🎯 このSkillでできること
下記の説明文を読むと、このSkillがあなたに何をしてくれるかが分かります。Claudeにこの分野の依頼をすると、自動で発動します。
📦 インストール方法 (3ステップ)
- 1. 上の「ダウンロード」ボタンを押して .skill ファイルを取得
- 2. ファイル名の拡張子を .skill から .zip に変えて展開(macは自動展開可)
- 3. 展開してできたフォルダを、ホームフォルダの
.claude/skills/に置く- · macOS / Linux:
~/.claude/skills/ - · Windows:
%USERPROFILE%\.claude\skills\
- · macOS / Linux:
Claude Code を再起動すれば完了。「このSkillを使って…」と話しかけなくても、関連する依頼で自動的に呼び出されます。
詳しい使い方ガイドを見る →- 最終更新
- 2026-05-18
- 取得日時
- 2026-05-18
- 同梱ファイル
- 1
📖 Claude が読む原文 SKILL.md(中身を展開)
この本文は AI(Claude)が読むための原文(英語または中国語)です。日本語訳は順次追加中。
LINE Notification Messages
Do not answer LINE Notification Messages questions from memory — LINE updates APIs frequently and training data is unreliable. Always consult the references below.
LINE Notification Messages allow sending messages to users by specifying their phone number (SHA256-hashed E.164 format), even if they haven't added the LINE Official Account as a friend. Corporate-only service available in Japan, Thailand, and Taiwan. Not for advertising or commercial purposes.
Workflow
Build
- Read references/api-common.md (rate limits, forward compatibility, error handling)
- Load the relevant reference for the feature being implemented
- For architecture or design choices, consult references/experts.md for directional guidance
- Write code following specs and constraints from references
Review / Debug
- Read references/api-common.md (rate limits, error codes)
- Load relevant references for the code being reviewed
- Cross-check code against specs (phone hashing format, sending conditions, consent states, billing rules, IP restriction warnings)
- For design pattern concerns, consult references/experts.md
- Report violations with reference to specific constraints
Environment Variables
LINE_CHANNEL_ACCESS_TOKEN=Bot access token (Messaging API channel)
LINE_CHANNEL_SECRET=Channel secret (webhook signature verification)
Common Specifications
Read references/api-common.md before writing any notification message code. Contains rules that affect all API interactions: forward compatibility (don't use strict schemas — LINE adds fields without notice), rate limits, error handling, and logging recommendations.
Two Message Types
| Type | Description | UX Review | Send Endpoint |
|---|---|---|---|
| Template | Predefined layout with templateKey, itemKey, buttonKey. Easy to set up. | Not required | POST /v2/bot/message/pnp/templated/push |
| Flexible | Free-form message objects (Flex Message, text, etc.). Greater design freedom. | Required | POST /bot/pnp/push |
- Template type added June 2025 — simpler, no UX review needed
- Flexible type (formerly just "LINE notification messages") — allows custom message objects but requires prior UX review
- Both types: no images, video, or audio allowed
Full type comparison → references/sending-api.md
Minimal Flow (pseudocode)
# 1. Hash phone number (E.164 → SHA256)
phone = "+818000001234" # E.164 format, no hyphens
hashed = SHA256(phone.encode()).hexdigest() # 64-char lowercase hex
# 2a. Send via template type
POST https://api.line.me/v2/bot/message/pnp/templated/push
Authorization: Bearer {channel_access_token}
X-Line-Delivery-Tag: {optional_tracking_tag}
{
"to": hashed,
"templateKey": "shipment_completed_ja",
"body": {
"emphasizedItem": {"itemKey": "date_002_ja", "content": "August 10"},
"items": [{"itemKey": "number_001_ja", "content": "1234567"}],
"buttons": [{"buttonKey": "contact_ja", "url": "https://example.com"}]
}
}
# → Response: 202 Accepted
# 2b. OR send via flexible type
POST https://api.line.me/bot/pnp/push
Authorization: Bearer {channel_access_token}
{
"to": hashed,
"messages": [{"type": "text", "text": "Your order has shipped"}]
}
# → Response: 200 OK
# 3. IMPORTANT: 200/202 does NOT guarantee delivery
# User may be blocked, consent not given, SMS auth expired, etc.
# 4. Delivery confirmation arrives via webhook
# event.type = "delivery", delivery.data = hashed phone or delivery tag
API Endpoint Summary
| Operation | Endpoint | Response |
|---|---|---|
| Send (Template) | POST /v2/bot/message/pnp/templated/push |
202 |
| Send (Flexible) | POST /bot/pnp/push |
200 |
| Count (Template) | GET /v2/bot/message/delivery/pnp/templated?date=yyyyMMdd |
200 |
| Count (Flexible) | GET /v2/bot/message/delivery/pnp?date=yyyyMMdd |
200 |
- Domain:
api.line.me - Rate limit: 2,000 req/sec for all endpoints
X-Line-Retry-Keyis NOT supported — do not use retry keys- Do NOT restrict server IP in channel Security Settings — may cause sending failure
Full API specs, parameters, error codes → references/sending-api.md
Key Concepts
Phone Number Hashing
- Normalize to E.164 format (country code, no hyphens):
+818000001234 - Hash with SHA256:
hashlib.sha256("+818000001234".encode()).hexdigest() - Result: 64-char lowercase hex string
Sending Conditions (ALL must be met)
- Phone number matches user's LINE account
- Phone number is valid (SMS authenticated)
- User agrees to receive LINE notification messages
- User has not blocked the LINE Official Account
- Phone number issued in Japan, Thailand, or Taiwan
- User has agreed to LINE's Privacy Policy (revised March 2022)
User Consent States
| State | Behavior |
|---|---|
| Agree (on) | Message delivered normally |
| Reject (off) | Message deleted, not delivered |
| Not set | User receives consent prompt; 24 hours to agree or message is deleted |
- Consent is comprehensive — once agreed, applies to ALL LINE Official Accounts
SMS Authentication
- Required once every 180 days
- Not required within 180 days of account creation or phone number change
Delivery Confirmation
- API response
200/202does NOT guarantee delivery - Use delivery completion webhook (
type: "delivery") to confirm actual delivery - No webhook within 24 hours = message was not delivered
Full technical specs → references/technical-specs.md Template system details → references/template-system.md Webhook details → references/delivery-webhook.md
Reference Index
| File | Topic |
|---|---|
| references/api-common.md | Read first. Rate limits, status codes, error handling, forward compatibility |
| references/sending-api.md | Send APIs (template + flexible), count APIs, request/response specs, error codes |
| references/template-system.md | Template structure: templateKey, itemKey, buttonKey, field limits, country suffixes |
| references/technical-specs.md | Phone hashing, sending conditions, consent flow, SMS auth, billing, IP restrictions |
| references/delivery-webhook.md | Delivery completion event, X-Line-Delivery-Tag, user consent flows, non-friend behavior |
| references/experts.md | LINE Notification Messages domain experts for architecture guidance |
SDK
Official SDKs: Python | Node.js | Go | Java | PHP | Ruby
Other languages: use LINE OpenAPI specs with OpenAPI Generator.