이용안내

미니톡 이용과 관련된 도움말을 제공합니다.
Minitalk.socket Defined : /scripts/widget.socket.js

미니톡 채팅서버와 미니톡 채팅위젯 사이에 소켓통신을 하기 위한 클래스입니다.

  • 이 기능은 문제의 소지가 있어 제거되었거나 제거될 예정입니다.
  • 아직 안정적이라고 고려될만큼 충분한 테스트를 거치지 않았습니다.(합당하다면 하위호환성이 보장됩니다.)
  • API가 충분히 검증되었지만, 기반이 되는 코드의 정리 때문에 마이너한 변경이 있을 수 있습니다.(하위호환성이 보장됩니다.)
  • 심각한 버그가 발견되지 않는 한 이 코드는 절대 변경되지 않습니다.
PROPERTIES
  • channel:

    접속한 채널에 대한 기본정보

    미니톡 채팅위젯이 현재 접속한 채널에 대한 기본정보가 담겨있습니다.


    object channel {

        string title : 접속한 채널명(미니톡 예제)
        string token : 미니톡 클라이언트 API호출을 위한 토큰
        boolean use_boxes : 개인박스 사용여부

        boolean use_users : 접속자목록 사용여부

        boolean use_history : 이전대화보기 사용여부 (v7.0.0 이상)

    }

    최종수정일 :
  • connected:

    미니톡 채팅서버에 접속중인지 여부

    미니톡 채팅서버에 접속이 되어있을 경우 true, 서버에 접속되지 않은 경우 false 로 정의된다.

    미니톡 채팅서버 접속완료가 되었음을 확인할 때는 이 변수값을 바로 참조하는 것보다 Minitalk.socket.isConnected() 메소드를 이용하는 것을 권장합니다.

    최종수정일 :
  • connecting:

    미니톡 채팅서버에 접속시도중 여부

    미니톡 채팅서버에 접속시도중인 경우 true, 접속이 완료되었거나, 접속이 끊어진 경우 false 로 정의된다.

    최종수정일 :
  • connection:

    미니톡 채팅서버에 접속하기 위한 정보

    미니톡 채팅서버에 접속하기 위한 데이터가 정의되어 있습니다.


    object connection {

        string domain : 미니톡 채팅서버 도메인

        string client_id : 미니톡 클라이언트 관리자 서버관리에서 정의된 클라이언트 아이디

        string channel : 채널설정이 담긴 암호화된 문자열

        string connection : 서버설정이 담긴 암호화된 문자열

    }

    최종수정일 :
  • io:

    서버소켓통신을 위한 socket.io 객체

    socket.io 객체가 정의되어 있습니다.

    socket.io 객체내에 정의된 변수 및 메소드와 관련된 사항은 https://socket.io 홈페이지 내 문서를 참고하시기 바랍니다.

    최종수정일 :
  • joined:

    미니톡 채팅서버에 접속후 채널에 참여했는지 여부

    미니톡 채팅서버에 접속후 채널에 참여가 되어 있을 경우 true, 채널에 참여하지 못하였을 경우 false 로 정의된다.

    미니톡 채팅서버 접속완료가 되었음을 확인할 때는 이 변수값을 바로 참조하는 것보다 Minitalk.socket.isConnected() 메소드를 이용하는 것을 권장합니다.

    최종수정일 :
  • permission:

    접속한 채널에 대한 나의 권한여부

    접속한 채널에 대한 나의 권한설정값이 정의되어 있습니다.


    object permission : {

        boolean box : 개인박스 개설 권한 여부
        boolean file : 파일전송 권한 여부
        boolean font : 폰트설정 권한 여부
        boolean nickname : 닉네임변경 권한 여부
        boolean send : 메시지전송 권한 여부
        boolean user : 접속자목록 보기 권한 여부
        boolean user_limit : 접속자목록에 보일 최소유저레벨

    }


    특정 권한이 있는지 확인하기 위해서는 해당 변수를 확인하는 것보다 Minitalk.socket.getPermission() 메소드를 이용하는 것을 권장합니다.

    최종수정일 :
  • reconnectable:

    미니톡 채팅서버와 연결이 해제되었을 경우 자동으로 재접속할지 여부

    미니톡 채팅서버와 어떠한 이유로 연결이 해제되었을 경우, 60초 뒤에 자동으로 재접속할지 여부를 정의한다.

    특정사유 (닉네임 중복 등)로 미니톡 채팅서버와의 연결이 해제되었을 경우에는 자동으로 재접속하지 않도록  false 로 정의된다.

    최종수정일 :
  • token:

    미니톡 채팅서버로 API 호출하기 위한 토큰

    미니톡 채팅서버로 API 호출을 하기 위한 토큰(접속자인증)이 정의되어 있습니다.

    최종수정일 :
  • uuid:

    나의 유저고유값

    특정 미니톡 채팅위젯의 특정채널에 접속한 나의 유저 고유값을 확인합니다.

    해당 유저고유값은 usercode 를 통해 고정된 닉네임이 정의되어 있는 경우, 해당 닉네임에 대해 고정된 유니크값이 정의되며, usercode 가 정의되지 않거나 고정된 닉네임이 없는 손님접속자의 경우, 브라우저를 완전히 종료하기 전 까지 고정된 유니크값이 정의됩니다.

    최종수정일 :
METHODS
  • connect():

    미니톡 채팅서버에 접속합니다.

    기본적으로 자동으로 호출되는 메소드로, 특별한 사유가 아닌 경우 해당 메소드를 이용하여 서버에 접속하는 것을 권장하지 않습니다.

    최종수정일 :
  • disconnect():

    미니톡 채팅서버와 접속을 해제합니다.

    미니톡 채팅서버와 접속을 해제합니다.

    해당 메소드로 접속을 해제한 경우 미니톡 채팅서버에 자동으로 재접속하지 않습니다.


    1
    2
    3
    4
    // 미니톡 채팅위젯 외부에서 특정 id 값을 가진 미니톡 채팅위젯의 서버연결을 해제합니다.
    MinitalkComponent.get("id").socket.disconnect();
    // 미니톡 채팅위젯 내부에서 서버연결을 해제합니다.
    Minitalk.socket.disconnect();
    최종수정일 :
  • isConnected():

    미니톡 채팅서버에 접속여부를 반환한다.

    미니톡 채팅서버 접속여부확인이 필요할 경우 사용합니다.


    1
    2
    3
    4
    // 미니톡 채팅위젯 외부에서 특정 id 를 가진 미니톡 채팅위젯의 접속여부를 확인할 경우
    MinitalkComponent.get("id").socket.isConnected();
    // 미니톡 채팅위젯 내부에서 미니톡 채팅위젯의 접속여부를 확인할 경우
    Minitalk.socket.isConnected();
    최종수정일 :
  • reconnect( time):

    특정시간 뒤에 미니톡 채팅서버에 접속을 시도합니다.

    미니톡 채팅서버와 접속이 해제되는 경우, 대부분 자동으로 해당 메소드가 호출됩니다.

    특정상황에서 재접속이 필요한 경우 해당 메소드를 호출하여 미니톡 채팅서버와 연결할 수 있습니다.

    해당 함수를 호출할때, Minitalk.socket.reconnectable 변수의 값이 false 일 경우 재접속하지 않습니다.


    int time : 재접속까지 대기할 시간(초)

    최종수정일 :
  • send( protocol [, data ]):

    미니톡 채팅서버에 데이터를 전송합니다.

    미니톡 채팅서버에 특정 프로토콜로 데이터를 전송합니다.

    데이터전송을 하기 위해서는 Minitalk.socket.permission.send 에 정의된 값이 true 여야 가능합니다. (일부 프로토콜은 제외)

    각 프로토콜 별 서버에 데이터를 보내는 함수가 따로 정의되어 있기 때문에, 해당 메소드로 직접 데이터를 서버에 전송하는 것은 권장하지 않습니다.

    최종수정일 :
  • sendMessage( type, message, data, isPrint):

    채팅메시지를 서버로 전송합니다.

    채팅메시지를 서버로 전송합니다.

    일반적으로 사용자가 메시지 입력폼에 내용을 입력하고, 전송버튼을 눌렀을 때와 동일한 방식으로, 일반적인 텍스트 메시지 뿐만 아니라 추가적인 데이터를 포함하여 전송할 수 있습니다.


    string type : 메시지 종류를 입력합니다. 일반적인 채팅메시지는 message 를 사용하면 미니톡 채팅위젯에 의해 자동으로 채팅메시지가 화면상에 구현됩니다.

    일반적인 채팅메시지가 아닌 특별한 디자인을 가진 메시지를 전송하시려면 string type 을 임의의 문자열로 정해 printMessage 이벤트를 이용하여 임의의 디자인을 가진 채팅메시지를 출력할 수 있습니다.

    string message : 메시지 내용

    object data : 채팅 메시지와 함께 전송할 추가적인 데이터로 해당 데이터는 printMessage 이벤트에서 받아 임의의 디자인을 가진 채팅메시지를 출력하는데 사용할 수 있습니다.

    boolean isPrint : 채팅메시지는 메시지를 수신한 사람만 화면에 출력되나, 이 값을 true 로 설정한 경우, 메시지를 전송한 사용자화면에서 해당 메시지가 출력됩니다.

    최종수정일 :
  • sendProtocol( protocol [, data = NULL, to = "*" ]):

    사용자정의 프로토콜을 전송한다.

    미니톡 채팅위젯에 기본적으로 정의된 프로토콜 외에 사용자정의 프로토콜을 서버에 전송하여, 접속자에게 데이터를 전송합니다.


    string protocol : 프로토콜명

    any data : 해당 프로토콜에 전송할 데이터 (string, object 등 모든 타입의 데이터를 전송할 수 있으며, 없을 경우 NULL 이 전송됩니다.)

    string to : 수신자 닉네임 (특정유저에게 전송할 경우 수신자 닉네임을 정의합니다. 없을 경우 전체 유저(*) 에게 전송됩니다.)


    정의된 사용자정의 프로토콜을 정의하는 방법에 대해서는 Minitalk.socket.setProtocol() 메소드 문서를 참고하세요.

    최종수정일 :
  • setProtocol( protocol, function):

    사용자정의 프로토콜을 정의한다.

    미니톡 채팅위젯에 기본적으로 정의된 프로토콜 외에 사용자정의 프로토콜을 추가하여 서버에 전송하거나, 수신할 때 실행될 함수를 정의할 수 있습니다.


    string protocol : 프로토콜명

    callback function : 해당 프로토콜을 수신하였을 경우, 실행할 함수


    콜백 함수의 매개변수로 아래와 같은 정보가 전달됩니다.

    callback function(

        Minitalk minitalk : 프로토콜을 수신한 미니톡 객체

        object data : 프로토콜에 담긴 데이터

        User to : 프로토콜을 수신한 유저객체 (전체 유저를 대상으로 전송된 프로토콜인 경우 "*" 을 반환한다.)

        User from : 프로토콜을 전송한 유저객체

    )


    정의된 사용자정의 프로토콜을 이용하여 데이터를 보내는 방법에 대해서는 Minitalk.socket.sendProtocol() 메소드 문서를 참고하세요.

    최종수정일 :