| | @@ -879,10 +879,88 @@ |
| 879 | 879 | } |
| 880 | 880 | blob_init(&chatDb, (const char*)pDb, (int)szDb); |
| 881 | 881 | cgi_set_content_type("application/x-sqlite3"); |
| 882 | 882 | cgi_set_content(&chatDb); |
| 883 | 883 | } |
| 884 | + |
| 885 | +/* |
| 886 | +** SQL Function: chat_msg_from_event(TYPE,OBJID,USER,MSG) |
| 887 | +** |
| 888 | +** This function returns HTML text that describes an entry from the EVENT |
| 889 | +** table (that is, a timeline event) for display in chat. Parameters: |
| 890 | +** |
| 891 | +** TYPE The event type. 'ci', 'w', 't', 'g', and so forth |
| 892 | +** OBJID EVENT.OBJID |
| 893 | +** USER coalesce(EVENT.EUSER,EVENT.USER) |
| 894 | +** MSG coalesce(EVENT.ECOMMENT, EVENT.COMMENT) |
| 895 | +** |
| 896 | +** This function is intended to be called by the temp.chat_trigger1 trigger |
| 897 | +** which is created by alert_create_trigger() routine. |
| 898 | +*/ |
| 899 | +void chat_msg_from_event( |
| 900 | + sqlite3_context *context, |
| 901 | + int argc, |
| 902 | + sqlite3_value **argv |
| 903 | +){ |
| 904 | + const char *zType = (const char*)sqlite3_value_text(argv[0]); |
| 905 | + int rid = sqlite3_value_int(argv[1]); |
| 906 | + const char *zUser = (const char*)sqlite3_value_text(argv[2]); |
| 907 | + const char *zMsg = (const char*)sqlite3_value_text(argv[3]); |
| 908 | + char *zRes = 0; |
| 909 | + |
| 910 | + if( zType==0 || zUser==0 || zMsg==0 ) return; |
| 911 | + if( zType[0]=='c' ){ |
| 912 | + /* Check-ins */ |
| 913 | + char *zBranch; |
| 914 | + char *zUuid; |
| 915 | + |
| 916 | + zBranch = db_text(0, |
| 917 | + "SELECT value FROM tagxref" |
| 918 | + " WHERE tagxref.rid=%d" |
| 919 | + " AND tagxref.tagid=%d" |
| 920 | + " AND tagxref.tagtype>0", |
| 921 | + rid, TAG_BRANCH); |
| 922 | + zUuid = db_text(0, "SELECT uuid FROM blob WHERE rid=%d", rid); |
| 923 | + zRes = mprintf("%W (check-in: <a href='%R/info/%S'>%S</a>, " |
| 924 | + "user: <a href='%R/timeline?u=%t&c=%S'>%h</a>, " |
| 925 | + "branch: <a href='%R/timeline?r=%t&c=%S'>%h</a>)", |
| 926 | + zMsg, |
| 927 | + zUuid, zUuid, |
| 928 | + zUser, zUuid, zUser, |
| 929 | + zBranch, zUuid, zBranch |
| 930 | + ); |
| 931 | + fossil_free(zBranch); |
| 932 | + fossil_free(zUuid); |
| 933 | + }else if( zType[0]=='w' ){ |
| 934 | + /* Wiki page changes */ |
| 935 | + char *zUuid; |
| 936 | + zUuid = db_text(0, "SELECT uuid FROM blob WHERE rid=%d", rid); |
| 937 | + wiki_hyperlink_override(zUuid); |
| 938 | + if( zMsg[0]=='-' ){ |
| 939 | + zRes = mprintf("Delete wiki page <a href='%R/whistory?name=%t'>%h</a>", |
| 940 | + zMsg+1, zMsg+1); |
| 941 | + }else if( zMsg[0]=='+' ){ |
| 942 | + zRes = mprintf("Added wiki page <a href='%R/whistory?name=%t'>%h</a>", |
| 943 | + zMsg+1, zMsg+1); |
| 944 | + }else if( zMsg[0]==':' ){ |
| 945 | + zRes = mprintf("<a href='%R/wdiff?id=%!S'>Changes</a> to wiki page " |
| 946 | + "<a href='%R/whistory?name=%t'>%h</a>", |
| 947 | + zUuid, zMsg+1, zMsg+1); |
| 948 | + }else{ |
| 949 | + zRes = mprintf("%W", zMsg); |
| 950 | + } |
| 951 | + wiki_hyperlink_override(0); |
| 952 | + fossil_free(zUuid); |
| 953 | + }else{ |
| 954 | + /* Anything else */ |
| 955 | + zRes = mprintf("%W", zMsg); |
| 956 | + } |
| 957 | + if( zRes ){ |
| 958 | + sqlite3_result_text(context, zRes, -1, fossil_free); |
| 959 | + } |
| 960 | +} |
| 961 | + |
| 884 | 962 | |
| 885 | 963 | /* |
| 886 | 964 | ** COMMAND: chat |
| 887 | 965 | ** |
| 888 | 966 | ** Usage: %fossil chat [SUBCOMMAND] [--remote URL] [ARGS...] |
| 889 | 967 | |