[BaaS] 데스크탑(VCL) 어플리케이션에서 특정 유저에게 GCM/APN 전송하기

2014.07.24 17:25

안녕하세요. 험프리.김현수입니다.


요즘 BaaS 코드아카데미 준비하느라 바쁘면서도 즐겁습니다. 새로운 내용을 공부하고 누군가에게 도움을 줄 수 있다는 것이 보람되네요^^(코드아카데미 참석해 주세요. 좋은 내용이 많습니다. http://tech.devgear.co.kr/404011)


이번에 소개해드릴 내용은 얼마전 어느분께서 데브기어를 통해 질문하신 내용입니다.

질문 내용은 "VCL로 푸시메시지를 브로드캐스트는 되는데 특정 사용자에게 전송 가능하느냐? "라는 질문이었습니다.


이 글을 이해하시기 위해서는  BaaS와 RAD Studio 글을 먼저 읽어보시고, 데스크탑에서 클라우드 메시지 전송 글을 선행해야 이글을 이해하시는데 도움이 많이 됩니다.

VCL 어플리케이션으로 특정 사용자에게 푸시메시지 전송

앞에서 안내해 드린 글을 데스크탑에서 클라우드 메시지 전송 보면 VCL 어플리케이션에서 Kinvey의 PushEndPoint를 이용해 브로드캐스트 메시지를 전송합니다.

특정사용자에게 전송할 때에도 PushEndPoint를 설정해 전송 할 수 있습니다. 

❑ 모바일 수신 설정(Custom Endpoint)

먼저 Kinvey에 접속해 Custom EndPoints(Addons > Business Logic > Custom Endpoints > New)를 추가합니다.

이름을 지정(저는 SpecificUsersMessage로 정했습니다.)하고, 다음의 코드를 입력하고 저장합니다.

function onRequest(request, response, modules){
    // 모듈
  var push = modules.push, 
      collectionAccess = modules.collectionAccess, 
      logger = modules.logger;
 
  // 데이터
  var iOSAps = request.body.iosaps;
  var iOSExtras = request.body.iosextras;
  var androidPayload = request.body.androidpayload;
  var username = androidPayload.username;

  if(username){
    collectionAccess.collection('user').findOne({'username': username}, function (err, user) {
      if (err) {
        logger.error('Query failed: '+ err);
      } else {
        if(user){
          // 사용자가 있으면 대상에게
          logger.info('Pushing message to ' + user.username);
          push.sendPayload(user, iOSAps, iOSExtras, androidPayload);
        } else {
          logger.error('Not found user!!(username: ' + username + ')');
        }
      }
   
      // 콜백함수 안에 있어야 합니다. 밖에 있으면 콜백함수 수행전 먼저 응답합니다.
      response.complete(200);    
    });
  } else {
    // username 미 지정 시 전체
    logger.info('Pushing message to All');
    push.broadcastPayload(iOSAps, iOSExtras, androidPayload);
  }
}

그리고 어플리케이션 제작 전 API Console을 이용해 아래의 코드로 테스트(참고)합니다.

{
  "iosaps": {
    "alert": "안녕하세요."
  }, 
  "iosextras": {
    "username": "testuser"
  }, 
  "androidpayload": {
    "username": "testuser",
    "message": "안녕하세요.",
    "title": "메시지 제목"
  }
}

위 내용 중 username 항목을 변경해 사용하시기 바랍니다.(Kinvey API 콘솔 에디터가 이상하게 복사/붙여넣기가 안되네요. 저만 그런가요? 타이핑해서 넣어서 사용하기 바랍니다.)

❑ VCL 전송 어플리케이션

앞에서 만든 EndPoints를 이용해 푸시메시지 전송하는 VCL 전송어플리케이션을 작성합니다.

VCL 폼의 디자인을 다음과 같이 대상(edtUserName) 항목을 추가하도록 수정합니다.(꼭 같을 필요는 없습니다.)

저는 전체에게 보낼지 대상을 지정할지 선택하기 위해 체크박스를 넣었습니다.


KinveyProvider의 PushEndPoint 속성에 앞에서 작성한 Custom EndPoints(SpecificUsersMessage)를 입력합니다.


메시지 전송 버튼에는 아래의 코드를 이용합니다.

var
  Data: TPushData;
begin
  Data := TPushData.Create;
  try
    Data.Message      := edtMessage.Text;
    Data.GCM.Title    := edtTitle.Text;
    Data.GCM.Message  := edtMessage.Text;

    if CheckBox1.Checked then
      Data.Extras.Add('username', edtUserName.Text);

    BackEndPush1.PushData(Data);
  finally
    Data.Free;
  end;

위 소스의 키포인트는 Data.Extras에 username을 추가하는 것입니다.

Extras 정보에 username을 추가하면 실제 전송되는 JSON 데이터에의 androidpayload와 iosextras에 username항목이 추가되고 Custom Endpoints에서 androidpayload의 username으로 특정 사용자에게 전송하도록 설정되었습니다.


BaaS를 이용하면 여러분들은 별도의 서버 준비 없이 서버기능인 백엔드 기능을 클라우드 기반의 서비스에서 이용할 수 있습니다.

한번 익혀두면 모바일 및 데스크탑에서 유용하게 사용할 수 있으니 도전해 보시기 바랍니다.



관련글

 

저작자 표시 비영리 동일 조건 변경 허락
신고
크리에이티브 커먼즈 라이선스
Creative Commons License

험프리.김현수 험프리.김현수 파이어몽키 APN, BAAS, Custom Endpoints, Delphi, gcm, Kinvey, vcl

Kinvey(BaaS)에서 Business Logic 디버깅(테스트, 로깅) 하기

2014.07.24 15:35

클라우드 서비스 중 백엔드 서비스를 이용할 수 있는 BaaS를 델파이에서 이용할 수 있는 것 많이들 아실텐데요.


사실 참고할 만한 내용이 많지 않아 아쉬울 따름입니다.(하지만 전세계적으로 사용량이 급증하고 있어 많은 참고할 글들이 곧 생긱것이라 확신합니다.) 제가 테스트하며 도움이 될만한 정보를 많이 남겨야겠습니다.

이상 사설이었구요.

Kinvey에서 비지니스 로직 디버깅하기

오늘은 BaaS 제공자 중 Kinvey에서 비지니스 로직을 만들 때 도움이 될만한  비지니스 로직을 디버깅 하는 내용에 관한 글입니다.

비지니스 로직은 일종의 함수라고 생각하면 됩니다. 사용자 및 파일이 추가되기 전/후(Before, After), 푸시메시지 요청 시 등록된 비지니스 로직이 호출됩니다.


오늘 제가 테스트한 내용은 푸시메시지 호출 시 특정 대상에게만 푸시메시지를 전송하는 비지니스 로직(onRequest)을 작성해봤습니다.(이 내용은 곧 포스팅 하겠습니다.

❑ 로그를 남기고 확인하기

비지니스 로직을 작성하다보면 예상한 결과대로 되지 않을때가 더 많습니다. 그때는 로그를 남겨야 하는데요. 다음과 같은 코드로 로그를 남길 수 있습니다.

var 
  logger = modules.logger;
  logger.info('request.body.username: ' + request.body.username);

그리고 로그를 확인하기 위해서는 에디터 아래의 logs 버튼을 누르면 로그 콘솔이 표시됩니다.


다음과 같은 형태로 로그가 표시됩니다.


❑ 비지니스 로직 테스트

매번 프로그램을 돌려 테스트하는 것보다 Kinvey 사이트 내에서 테스트하는 것이 더 간단합니다.

Addons > Developer Tools > API Console로 API 콘솔 화면으로 이동합니다.


좌측메뉴에서 대상 비지니스 로직을 선택하고, Headers를 추가하거나 필요한 내용의 body 내용을 추가 후 Send Request 버튼을 누르면 비지니스 로직이 동작합니다.

body 내용은 푸시메시지를 받는 사용자정보를 넣어봤습니다. JSON 포맷으로 작성해야 합니다.


다음과 같이 HTTP/1.1 200으로 나오면 잘 동작한 것입니다. 물론 로그를 통해 과정도 확인해야 합니다.


만약 문법상의 오류가 있다면 아래와 같이 HTTP/1.1 400형태의 응답이 오고, 하단에 error, description, debug 항목을 통해 오류의 내용을 안내합니다.


저작자 표시 비영리 동일 조건 변경 허락
신고
크리에이티브 커먼즈 라이선스
Creative Commons License

험프리.김현수 험프리.김현수 파이어몽키 BAAS, Business logic, Delphi, Kinvey

  1. 큰 도움이 되는 글이네요. BaaS 쓰는 분 보게 되어 반갑습니다.

  2. 큰 도움이 되는 글이네요. BaaS 쓰는 분 보게 되어 반갑습니다.

Baas(Backend as a Service)와 RAD Studio(GCM, APN, 푸시알림 가능)

2014.05.27 11:36

BaaS(Backend as a Service)

BaaS는 Backend as a Service 약자로 모바일에서 필요한 Backend 기능을 추상화하여 표준 API(JSON 등)로 제공하는 클라우드 서비스의 한 종류 입니다.

Backend as a service - http://en.wikipedia.org/wiki/BaaS


더보기


간단히 설명하면, 여러분이 앱을 만드는 경우 앱에서 사용하기 위한 데이터, 사용자 정보등의 Backend 기능을 여러분의 서버에 구성하지 않고, BaaS 사이트(또는 연동)에서 제공하는 기능을 설정(커스터마이징) 후 이용하는 방식입니다. 별도의 여러분의 Backend 서비스 개발 과정이 생략되어 개발 시간을 대폭 단축 할 수 있습니다.


대표적인 BaaS 제공자로는 Kinvey, Pharse, Bass.io(국내)가 있으며 제공되는 기능은 푸시알림, SNS 연동, 사용자 관리, 데이터 관리, 이미지/사운드 등의 파일 관리 등이 있습니다.


RAD Studio XE6에서도 새롭게 BaaS 관련된 컴포넌트가 추가되었습니다.


현재는 대표적인 BaaS 서비스인 Kinvey와 Pharse를 제공합니다.

BaaS 컴포넌트


BaaS 컴포넌트는 위와 같이 제공자 컴포넌트와 서비스 기능 컴포넌트로 구분됩니다.

서비스 기능 컴포넌트는 BaaS에서 제공되는 대표적인 기능을 사용할 수 있는 컴포넌트이며, 기능별로 추상화(표준화)되어 제공되어 제공자별로 별도로 구성하지 않아도 됩니다. 앱 개발 시 서비스 기능 위주로 개발하고 제공자를 연결하면 제공자의 서비스와 연결되도록 아주 유연한 구조로 설계가 되어있습니다.

즉, 향후 제공자가 추가된다면, 기존에 구현된 기능을 그대로 사용하고 제공자 컴포넌트만 변경해 적용 할 수 있습니다. 


그리고 BaaS 컴포넌트는 멀티플랫폼을 지원하여, VCL과 FMX에서 모두 사용이 가능합니다.

즉, VCL에서 사용자 및 데이터 관리와 푸시메시지 전송등을 기존의 어플리케이션에서 적용할 수도 있습니다.

BaaS 관련 샘플

다음은 엠바카데로에서 제공하는 BaaS 컴포넌트 관련 설명과 샘플소스입니다. 

(개인적으로 GCM 부분을 따라해 봤는데 아주 쉽게 되었습니다.)

▶ Remote Notification(GCM, APN)


Mobile Tutorial: Using Remote Notifications


메시징 서비스 설정 - 구글과 애플에서 클라우드 서비스 사용을 위한 설정


클라우드 서비스에 구글과 애플 계정 연결 설정


어플리케이션 구현 - 컴포넌트를 이용 클라우드 메시지 수신하도록 구현 및 테스트


데이터에 트리거(Trigger)를 걸어 데이터 변경 시 데이터 전송

데스크탑에서 클라우드 메시지 전송


▶ Storage 이용

BaaS 컴포넌트를 이용한 ToDo List


사용자 계정관리(생성)


▶ 파일 업로드/다운로드


Uploading images to the cloud with BaaS in RAD Studio XE6


C++빌더 샘플 다운로드


      ▶ VCL 어플리케이션에서 특정 사용자에게 푸쉬메시지 전송

      Custom Endpoint 설정과 어플리케이션 데모

      참고



      관련글



      저작자 표시 비영리 동일 조건 변경 허락
      신고
      크리에이티브 커먼즈 라이선스
      Creative Commons License

      험프리.김현수 험프리.김현수 파이어몽키 BAAS, Delphi, Kinvey, Pharse, Rad Studio

      1. Blog Icon
        희아

        문의드립니다. XE6 에서의 GCM 지원은 결국 상용화되어있는 것을 이용하는 것 뿐인가요?
        메시지밖에 안보내는데도...
        비용을 들이지 않고 작업하려면 Send/Receive 를 통신이나 java를 이용하여 개발해 포함시켜야 하는건가요?
        XE5 에서 개발된 샘플을 이용해보려하는데 쉽지않네요.

      2. 네 BaaS를 사용하지 않으려면 위글의 참고 항목의 링크를 확인하시면 직접 GCM/APN을 구현할 수 있습니다.
        말씀하신대로 BaaS 컴포넌트를 이용할때 보다 상당히 어렵습니다.

      3. Blog Icon
        정상언

        국내 bass.io 서비스는 7월28일자로 종료되었다네요
        https://www.facebook.com/backendservice