コンテンツの読み込みに時間がかかっています

Zoho Flowを活用したXへのブログ自動投稿の設定方法


ウェブサイトのコンテンツを自動で X に POST するには、どうしたらいいの?って問い合わせがあったので、自分のブログで設定をしてみた。以前は、ifttt.com とかで無料で可能であったが、X の投稿API が数が多いと有料化されたりしたこともあり無料で使えなくなっている。

そこで、今回は既にサブスクで利用している Zoho の同様のサービス Zoho Flow を使って設定をしてみた。方法をメモって公開しておく。



フローの実行条件

  • アプリ : アプリで処理が発生したときに実行されます。例:Zoho CRMに新しい見込み客が追加されたとき
  • スケジュール : 設定したスケジュールに基づいて、フローを1度のみまたは繰り返し実行します
  • Webhook : WebhookのURLを通じてアプリやコードからデータを受信し、処理を実行します
  • URL : URLを定期的にポーリングし、新しいデータが見つかったときにフローをトリガーする。(Polls a URL periodically and triggers the flow when new data is found)
  • E-mail : テンプレートは、メールトリガーが受信メールを解析し、そこから変数を抽出することを可能にします。(A template enables email triggers to parse incoming emails and extract variables from them)
  • RSS/Atom Feed : 指定したRSSまたはAtomフィードに新しいアイテムが投稿されたときにトリガーが発生する(Triggers when a new item is posted in the specified RSS or Atom feed)

a-blog cms で Tweet の引用をブログにお手軽に実装する方法

https://publish.twitter.com/ を一度ご確認ください。上記のようなサイトがあります。以前は Twitter の Widgets が設定画面にあって、そこでコードをコピペするような感じで提供されていたが、いつの日か無くなってしまっていたと思っていたのですが、いつの間にか復活しておりました。



機能としては、Embedded Tweet / Embedded Timeline / Twitter Buttons の3種類が用意されています。 Buttons はクリックすると 5種類あるみたいですが、今回は全く確認していない。 Timeline も便利に使えそうではあるが、今回は Embedded Tweet のお話です。

a-blog cms の標準的な引用ユニット


blogテーマでは、デフォルトは表示されていないが「引用ユニット」をオンにすると以下のように URL を設定できるようになっている。そこで、https://www.a-blogcms.jp を設定すると、そのページの OGP情報を取得して表示してくれる便利な機能だ。


a-blog cms のテキストユニットでの引用


一般的なテキストの引用については、こんな感じで書くと <blockquote> 〜 </blockquote> のタグで囲まれた文章となる。

さらに脱線気味に cite属性を追加する方法

管理画面 / コンフィグ / エントリー / 編集設定 / テキストタグセレクト の3つ目の入力欄に「引用元URL」と設定します。


上記の設定を行うと以下ような感じで引用元URLを設定できるユニットに進化します。


あとは blog/include/unit.html@section(text-unit) を持ってきて blockquoteブロック をカスタマイズします。3つ目の入力欄の変数は {extend_tag} となっています。

<!-- BEGIN blockquote -->
<div class="entry-container">
<blockquote{class}<!-- BEGIN_IF [{extend_tag}/nem] --> cite="{extend_tag}"<!-- END_IF -->>
{text}[raw|nl2br]</blockquote></div><!-- END blockquote -->

本題の引用ユニットに Embedded Tweet 機能を追加

例えば https://twitter.com/ndrf_kazumich/status/1510118505139798019https://publish.twitter.com/ に設定します。

<blockquote class="twitter-tweet">
<p lang="ja" dir="ltr">今日は朝早起きしたので、a-backup を作り直している。処理を簡単にして短い時間で処理が完了できるようにすることを第一の目標とし、2つ目の目標として設定項目を減らして簡単に使えるようにする。テーマの設定を DB を確認して出来るようになった。 
<a href="https://t.co/5IFYxsPJDq">pic.twitter.com/5IFYxsPJDq</a></p>&mdash; 山本一道@アップルップル (@kazumich) <a href="https://twitter.com/kazumich/status/1601727082824105985?ref_src=twsrc%5Etfw">December 10, 2022</a>
</blockquote> 
<script async src="https://platform.twitter.com/widgets.js" charset="utf-8"></script>

こんな事が書ければ OK な事がわかります。

実は blog テーマは、https://platform.twitter.com/widgets.js が最初から読み込まれているので、<script> タグは消しても動作します。

オリジナルテーマで実装する際には widgets.js が必要になります。必要な時に読み込むようにカスタマイズするには「SetRendered と GET_Rendered を活用した「円グラフのカスタムユニット」を作ってみよう」を参考にしてください。

徐々に情報を減らして動くかを調べてみたところ、class="twitter-tweet" の中の <a> の href 属性に Twitter の URL があるだけで動作する事がわかりました。

テンプレートをカスタマイズしていきます

blog/include/unit.html には最初から @section(quote-unit) がカスタマイズして設置されていました。そこの一部が以下のように書かれています。

(略)
<!-- BEGIN html:veil -->
 {quote_html}[raw]
<!-- END html:veil -->
<!-- BEGIN_IF [{quote_title}/nem/] -->
<blockquote class="quote">
(略)

<-- END html:veil --> の後ある IFブロックを少し修正し、以下のようにします。

(略)
<!-- BEGIN html:veil -->
 {quote_html}[raw]
<!-- END html:veil -->
<!-- BEGIN_IF [{quote_url}/lk/twitter.com] -->
 <blockquote class="twitter-tweet">
  <a href="{quote_url}">Tweet内容をtwitter.comで確認する</a>
 </blockquote>
<!-- ELSE_IF [{quote_title}/nem/] -->
<blockquote class="quote">
(略)

<blockquote>タグclass="twitter-tweet" をつけ、その中の <a>タグ に Tweet の URL を設定するだけOKです。


と設定すれば、以下のような感じになります。


引用機能の隠れた機能?

ローカルでテストしつつ、このブログにも実装しておこう!って作業をしたらこの設定をしないでも、引用ユニットに Twitter の URL を設定するだけで同じものが表示されてしまいました。

コンフィグの設定で Twitter API を設定すると OGP の代わりに、今回の https://publish.twitter.com/ の結果と同じタグを twitter.com から API 経由で持ってきてくれることを忘れておりました。これも、せっかくなのでお伝えしておきます。


@webbingstudio と @ohtsuki2843 の Tweet が嬉しかったのでペタペタ貼ってみた

a-blog cms 春合宿が終わった翌日に @webbingstudio が以下の Tweet をし、それを RT しつつ @ohtsuki2843 も嬉しい Tweet をしていたので、嬉しくなってペタペタ貼ってみた。a-blog cms の引用ユニットは、Twitter の URL を入力すると以下のような感じになります。



Twitter と Facebook に写真付きの投稿するには Instagram と IFTTT を連携して使うのがオススメ


ベースキャンプ名古屋 での活動をアルバイトの子に Twitter ( @basecamp758 ) と Facebook ページ ( basecamp758 ) にアップしてもらっていますが、1回で両方に簡単にアップできるようにすることができないかを考えて instagram ( basecamp758 ) を利用することにしてみました。


CSS Nite LP15「ソーシャルメディア特集」

前日、東京に来ていた事もあり CSS Nite に参加する事にした。 Twitter や facebook のセミナーについては、参加して良かったというものが少なかったが、今回の CSS Nite LP15 はさすがですね。いいイベントだったと思います。

中でも Web担当者Forum の編集長の安田さんのセッションは、もっと長くていろいろ聞きたいと思うものでした。できれば、名古屋にも来て欲しい!と思っています。(年4回で2-3人のWCANでは呼べる人数に限りがあるので人選が難しいです) CSS Nite では、ビジネスでの活用をどうするかという事よりも、実装をどうするという話の法が、CSS Nite っぽいですね。

やはり今は Twitter や facebook は外せないという事を再認識し、a-blog cms 1.4.2 について何らかの連携機能を標準実装していくようにしようと思ったりしました。(どうなるかは未定ですが...)


政治ったーを公開しました


本日、アップルップルの最新の制作事例として「政治ったー」というサイトを公開した。これは a-blog cms をフレームワークとして使い、Twitter API と仲良しになって、政治関連のIDを集めたサイトになります。