現在表示中:

このページでは、メッセージングコンポーネントを使用してメッセージング機能を Web サイトに組み込む方法の詳細をまとめています。

クライアント側の基本事項

メッセージを作成
 resourceType

social/messaging/components/hbs/composemessage

clientllibs

cq.social.hbs.messaging

テンプレート /libs/social/messaging/components/hbs/message/message.hbs
css /libs/social/messaging/components/hbs/message/clientlibs/message/message.css
プロパティ メッセージング機能を参照
管理設定 ソーシャルメッセージングの設定
メッセージリスト
 resourceType

social/messaging/components/hbs/messagebox

クライアント側のカスタマイズも参照してください。

サーバー側の基本事項

警告:

次の MessageBuilder メソッドの文字列パラメーターには、末尾のスラッシュを含めないでください

  • setInboxPath()
  • setSentItemsPath()

次に例を示します。

    valid : mb.setInboxPath( "/mail/inbox" );
not valid : mb.setInboxPath( "/mail/inbox/" );

コミュニティサイト

ウィザードを使用して作成したコミュニティサイト構造には、選択したメッセージング機能が含まれています。コミュニティサイトコンソールユーザー管理設定を参照してください。

sortmail.jsp

サンプルコード:メッセージ受信通知

ソーシャルメッセージング機能では、送信既読削除などの操作に応じてイベントがスローされます。これらのイベントをキャッチし、イベントに含まれているデータを処理できます。

次の例は、メッセージ送信イベントをリッスンし、Day CQ Mail Service を使用してすべてのメッセージ受信者に電子メールを送信するイベントハンドラーを示しています。

サーバー側サンプルスクリプトを試すには、開発環境と OSGi バンドルのビルド機能が必要です。

  1. 管理者として CRXDE|Lite にログインします。
  2. /apps/geometrixx/install に次のような任意の名前のバンドルノードを作成します。
    • シンボリック名:com.geometrixx.media.social.messaging.MessagingNotification
    • 名前:Geometrixx Message Notificaton
    • 説明:a sample service for sending an email notification to users when they receive a message
    • パッケージ:com.geometrixx.media.social.messaging.notification
  3. /apps/geometrixx/install/com.geometrixx.media.social.messaging.MessagingNotification/src/main/java/com/geometrixx/media/social/messaging/notification に移動します。
    1. 自動的に作成された Activator.java クラスを削除します。
    2. MessageEventHandler.java クラスを削除します。
    3. 次のコードを MessageEventHandler.java にコピーするか、貼り付けます。
  4. すべて保存」をクリックします。
  5. /apps/geometrixx/install/com.geometrixx.media.social.messaging.MessagingNotification/com.geometrixx.media.social.messaging.MessagingNotification.bnd に移動し、MessageEventHandler.java コードに記述されている import ステートメントをすべて追加します。
  6. バンドルをビルドします。
  7. Day CQ Mail Service OSGi サービスが設定されていることを確認します。
  8. デモユーザーの 1 つでログインし、別のユーザーに電子メールを送信します。
  9. 新規メッセージに関する電子メールが受信者に届きます。

MessageEventHandler.java

package com.geometrixx.media.social.messaging.notification;

import org.apache.felix.scr.annotations.Component;
import org.apache.felix.scr.annotations.Properties;
import org.apache.felix.scr.annotations.Property;
import org.apache.felix.scr.annotations.Service;
import org.apache.felix.scr.annotations.Reference;
import org.apache.sling.api.resource.ResourceResolver;
import org.apache.sling.api.resource.ResourceResolverFactory;
import org.apache.sling.api.resource.Resource;
import org.apache.commons.mail.Email;
import org.apache.commons.mail.EmailException;
import org.apache.commons.mail.SimpleEmail;
import org.apache.commons.mail.HtmlEmail;
import java.util.List;
import org.osgi.service.event.Event;
import org.osgi.service.event.EventHandler;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import com.adobe.cq.social.messaging.api.Message;
import com.adobe.cq.social.messaging.api.MessagingEvent;
import com.day.cq.mailer.MessageGatewayService;
import com.day.cq.mailer.MessageGateway;

@Component(immediate=true)
@Service(EventHandler.class)
@Properties({
        @Property(name = "event.topics", value = "com/adobe/cq/social/message")
})
public class MessagingEventHandler implements EventHandler {
    private Logger logger = LoggerFactory.getLogger(MessagingEventHandler.class);

    @Reference
    ResourceResolverFactory resourceResolverFactory;

    @Reference
    private MessageGatewayService messageGatewayService;

    ResourceResolver resourceResolver=null;
    MessageGateway messageGateway=null;

    public void sendMail(String from, String to,String subject, String content){
        Email email = new SimpleEmail();
        messageGateway = messageGatewayService.getGateway(SimpleEmail.class);
        try {
         email.addTo(to);
            email.addReplyTo(from);
            email.setFrom(from);
            email.setMsg(content);
            email.setSubject(subject);
         messageGateway.send(email);
        } catch(EmailException ex) {
            logger.error("MessageNotificaiton : Error sending email : "+ex.getMessage());
        }
        logger.info("**** MessageNotification ****  Mail sent to " + to);
    }

    public void handleEvent(Event event) {
        //Get Message Path and originator User's ID from event
        String messagePath = (String) event.getProperty("path");
        String senderId = (String) event.getProperty("userId");
        MessagingEvent.MessagingActions action = (MessagingEvent.MessagingActions) event.getProperty("action");
        try{
            if(MessagingEvent.MessagingActions.MessageSent.equals(action)){
                resourceResolver = resourceResolverFactory.getAdministrativeResourceResolver(null);

                //Read message
                Resource resource = resourceResolver.getResource(messagePath);
                Message msg = resource.adaptTo(Message.class);

                //Get list of recipient Ids from message
                //For Geometrixx, Id is same as email. If that is not the case in your site, 
                //an additional step is needed to retrieve the email for the Id
                List<String> reclist = msg.getRecipientIdList();
                for(int i=0;i<reclist.size();i++){
                    //Send Email using Mailing Service
                    sendMail("admin@cqadmin.qqq",reclist.get(i),"New message on Geometrixx", "Hi\nYou have received a new message from  " +  senderId + ". To read it, sign in to Geometrixx.\n\n-Geometrixx Admin");
                }
            }
        } catch(Exception ex){
            logger.error("Error getting message info : " + ex.getMessage());
        } finally {
            resourceResolver.close();
        }

    }
}

本作品は Creative Commons Attribution-Noncommercial-Share Alike 3.0 Unported License によってライセンス許可を受けています。  Twitter™ および Facebook の投稿には、Creative Commons の規約内容は適用されません。

法律上の注意   |   プライバシーポリシー