Added support for authenticated SMTP. I'm going to do a few tests on this tonight.

Added 87 new emoji shortcodes. We now have all of the Unicode v1.1 emojis covered.
Added support for #fid hashlinks.
Added the :(, :O, :o, and :p smiley codes.

Fixed a bug where the topic data wasn't getting updated after creating a reply.

Added the get_forum function.
Added the get_forum_copy function.
Added the build_forum_url function.
This commit is contained in:
Azareal 2017-03-15 08:34:14 +00:00
parent ca7c369e9e
commit 3662a298d4
7 changed files with 167 additions and 14 deletions

View File

@ -21,8 +21,12 @@ var staff_css = " background-color: #ffeaff;"
var uncategorised_forum_visible = true
var enable_emails = false
var site_name = "Test Install" // Should be a setting
var site_email = "" // Should be a setting
var smtp_server = ""
var smtp_username = ""
var smtp_password = ""
//var noavatar = "https://api.adorable.io/avatars/{width}/{id}@{site_url}.png"
var noavatar = "https://api.adorable.io/avatars/285/{id}@" + site_url + ".png"
var items_per_page = 25

View File

@ -98,6 +98,13 @@ CREATE TABLE `replies`(
primary key(`rid`)
) CHARSET=utf8mb4 COLLATE utf8mb4_general_ci;
CREATE TABLE `revisions`(
`index` int not null,
`content` text not null,
`contentID` int not null,
`contentType` varchar(100) DEFAULT 'replies' not null
) CHARSET=utf8mb4 COLLATE utf8mb4_general_ci;
CREATE TABLE `users_replies`(
`rid` int not null AUTO_INCREMENT,
`uid` int not null,

View File

@ -1,5 +1,6 @@
package main
//import "fmt"
import "strconv"
import "database/sql"
import _ "github.com/go-sql-driver/mysql"
@ -78,10 +79,24 @@ func delete_forum(fid int) error {
return nil
}
func get_forum(fid int) (forum *Forum, res bool) {
if !((fid <= forumCapCount) && (fid >= 0) && forums[fid].Name!="") {
return forum, false
}
return &forums[fid], true
}
func get_forum_copy(fid int) (forum Forum, res bool) {
if !((fid <= forumCapCount) && (fid >= 0) && forums[fid].Name!="") {
return forum, false
}
return forums[fid], true
}
func forum_exists(fid int) bool {
//fmt.Println(fid)
//fmt.Println(fid <= forumCapCount)
//fmt.Println(fid >= 0)
//fmt.Println(forums[fid].Name!="")
return (fid <= forumCapCount) && (fid >= 0) && forums[fid].Name!=""
}
func build_forum_url(fid int) string {
return "/forum/" + strconv.Itoa(fid)
}

View File

@ -159,8 +159,12 @@ var staff_css = " background-color: #ffeaff;"
var uncategorised_forum_visible = true
var enable_emails = false
var site_name = "` + site_name + `" // Should be a setting
var site_email = "" // Should be a setting
var smtp_server = ""
var smtp_username = ""
var smtp_password = ""
//var noavatar = "https://api.adorable.io/avatars/{width}/{id}@{site_url}.png"
var noavatar = "https://api.adorable.io/avatars/285/{id}@" + site_url + ".png"
var items_per_page = 25

125
pages.go
View File

@ -103,6 +103,7 @@ var http_prot_b []byte = []byte("http://")
var invalid_url []byte = []byte("<span style='color: red;'>[Invalid URL]</span>")
var invalid_topic []byte = []byte("<span style='color: red;'>[Invalid Topic]</span>")
var invalid_profile []byte = []byte("<span style='color: red;'>[Invalid Profile]</span>")
var invalid_forum []byte = []byte("<span style='color: red;'>[Invalid Forum]</span>")
var url_open []byte = []byte("<a href='")
var url_open2 []byte = []byte("'>")
var bytes_singlequote []byte = []byte("'")
@ -156,6 +157,94 @@ func shortcode_to_unicode(msg string) string {
msg = strings.Replace(msg,":relieved:","😌",-1)
msg = strings.Replace(msg,":nerd:","🤓",-1)
msg = strings.Replace(msg,":stuck_out_tongue:","😛",-1)
msg = strings.Replace(msg,":worried:","😟",-1)
msg = strings.Replace(msg,":drooling_face:","🤤",-1)
msg = strings.Replace(msg,":disappointed:","😞",-1)
msg = strings.Replace(msg,":astonished:","😲",-1)
msg = strings.Replace(msg,":slight_frown:","🙁",-1)
msg = strings.Replace(msg,":skull_crossbones:","☠️",-1)
msg = strings.Replace(msg,":skull:","💀",-1)
msg = strings.Replace(msg,":point_up:","☝️",-1)
msg = strings.Replace(msg,":v:","✌️️",-1)
msg = strings.Replace(msg,":writing_hand:","✍️",-1)
msg = strings.Replace(msg,":heart:","❤️️",-1)
msg = strings.Replace(msg,":heart_exclamation:","❣️",-1)
msg = strings.Replace(msg,":hotsprings:","♨️",-1)
msg = strings.Replace(msg,":airplane:","✈️️",-1)
msg = strings.Replace(msg,":hourglass:","⌛",-1)
msg = strings.Replace(msg,":watch:","⌚",-1)
msg = strings.Replace(msg,":comet:","☄️",-1)
msg = strings.Replace(msg,":snowflake:","❄️",-1)
msg = strings.Replace(msg,":cloud:","☁️",-1)
msg = strings.Replace(msg,":sunny:","☀️",-1)
msg = strings.Replace(msg,":spades:","♠️",-1)
msg = strings.Replace(msg,":hearts:","♥️️",-1)
msg = strings.Replace(msg,":diamonds:","♦️",-1)
msg = strings.Replace(msg,":clubs:","♣️",-1)
msg = strings.Replace(msg,":phone:","☎️",-1)
msg = strings.Replace(msg,":telephone:","☎️",-1)
msg = strings.Replace(msg,":biohazard:","☣️",-1)
msg = strings.Replace(msg,":radioactive:","☢️",-1)
msg = strings.Replace(msg,":scissors:","✂️",-1)
msg = strings.Replace(msg,":arrow_upper_right:","↗️",-1)
msg = strings.Replace(msg,":arrow_right:","➡️",-1)
msg = strings.Replace(msg,":arrow_lower_right:","↘️",-1)
msg = strings.Replace(msg,":arrow_lower_left:","↙️",-1)
msg = strings.Replace(msg,":arrow_upper_left:","↖️",-1)
msg = strings.Replace(msg,":arrow_up_down:","↕️",-1)
msg = strings.Replace(msg,":left_right_arrow:","↔️",-1)
msg = strings.Replace(msg,":leftwards_arrow_with_hook:","↩️",-1)
msg = strings.Replace(msg,":arrow_right_hook:","↪️",-1)
msg = strings.Replace(msg,":arrow_forward:","▶️",-1)
msg = strings.Replace(msg,":arrow_backward:","◀️",-1)
msg = strings.Replace(msg,":female:","♀️",-1)
msg = strings.Replace(msg,":male:","♂️",-1)
msg = strings.Replace(msg,":ballot_box_with_check:","☑️",-1)
msg = strings.Replace(msg,":heavy_check_mark:","✔️️",-1)
msg = strings.Replace(msg,":heavy_multiplication_x:","✖️",-1)
msg = strings.Replace(msg,":pisces:","♓",-1)
msg = strings.Replace(msg,":aquarius:","♒",-1)
msg = strings.Replace(msg,":capricorn:","♑",-1)
msg = strings.Replace(msg,":sagittarius:","♐",-1)
msg = strings.Replace(msg,":scorpius:","♏",-1)
msg = strings.Replace(msg,":libra:","♎",-1)
msg = strings.Replace(msg,":virgo:","♍",-1)
msg = strings.Replace(msg,":leo:","♌",-1)
msg = strings.Replace(msg,":cancer:","♋",-1)
msg = strings.Replace(msg,":gemini:","♊",-1)
msg = strings.Replace(msg,":taurus:","♉",-1)
msg = strings.Replace(msg,":aries:","♈",-1)
msg = strings.Replace(msg,":peace:","☮️",-1)
msg = strings.Replace(msg,":eight_spoked_asterisk:","✳️",-1)
msg = strings.Replace(msg,":eight_pointed_black_star:","✴️",-1)
msg = strings.Replace(msg,":snowman2:","☃️",-1)
msg = strings.Replace(msg,":umbrella2:","☂️",-1)
msg = strings.Replace(msg,":pencil2:","✏️",-1)
msg = strings.Replace(msg,":black_nib:","✒️",-1)
msg = strings.Replace(msg,":email:","✉️",-1)
msg = strings.Replace(msg,":envelope:","✉️",-1)
msg = strings.Replace(msg,":keyboard:","⌨️",-1)
msg = strings.Replace(msg,":white_small_square:","▫️",-1)
msg = strings.Replace(msg,":black_small_square:","▪️",-1)
msg = strings.Replace(msg,":secret:","㊙️",-1)
msg = strings.Replace(msg,":congratulations:","㊗️",-1)
msg = strings.Replace(msg,":m:","Ⓜ️",-1)
msg = strings.Replace(msg,":tm:","™️️",-1)
msg = strings.Replace(msg,":registered:","®️",-1)
msg = strings.Replace(msg,":copyright:","©️",-1)
msg = strings.Replace(msg,":wavy_dash:","〰️",-1)
msg = strings.Replace(msg,":bangbang:","‼️",-1)
msg = strings.Replace(msg,":sparkle:","❇️",-1)
msg = strings.Replace(msg,":star_of_david:","✡️",-1)
msg = strings.Replace(msg,":wheel_of_dharma:","☸️",-1)
msg = strings.Replace(msg,":yin_yang:","☯️",-1)
msg = strings.Replace(msg,":cross:","✝️",-1)
msg = strings.Replace(msg,":orthodox_cross:","☦️",-1)
msg = strings.Replace(msg,":star_and_crescent:","☪️",-1)
msg = strings.Replace(msg,":frowning2:","☹️",-1)
msg = strings.Replace(msg,":information_source:","",-1)
msg = strings.Replace(msg,":interrobang:","⁉️",-1)
return msg
}
@ -167,24 +256,20 @@ func preparse_message(msg string) string {
return shortcode_to_unicode(msg)
}
//var msg_index int = 0
func parse_message(msg string/*, user User*/) string {
msg = strings.Replace(msg,":)","😀",-1)
msg = strings.Replace(msg,":(","😞",-1)
msg = strings.Replace(msg,":D","😃",-1)
msg = strings.Replace(msg,":P","😛",-1)
msg = strings.Replace(msg,":O","😲",-1)
msg = strings.Replace(msg,":p","😛",-1)
msg = strings.Replace(msg,":o","😲",-1)
//msg = url_reg.ReplaceAllString(msg,"<a href=\"$2$3//$4\" rel=\"nofollow\">$2$3//$4</a>")
// Search for URLs, mentions and hashlinks in the messages...
//fmt.Println("Parser Loop!")
//fmt.Println("Message Index:")
//msg_index++
//fmt.Println(msg_index)
var msgbytes = []byte(msg)
var outbytes []byte
//fmt.Println("Outbytes Start:")
//fmt.Println(outbytes)
//fmt.Println(string(outbytes))
//fmt.Println("Outbytes Start End:")
msgbytes = append(msgbytes,space_gap...)
//fmt.Println(`"`+string(msgbytes)+`"`)
lastItem := 0
@ -205,7 +290,6 @@ func parse_message(msg string/*, user User*/) string {
if (i==0 && (msgbytes[0] > 32)) || ((msgbytes[i] < 33) && (msgbytes[i + 1] > 32)) {
//fmt.Println("IN")
//fmt.Println(msgbytes[i])
//fmt.Println("STEP CONTINUE")
if (i != 0) || msgbytes[i] < 33 {
i++
}
@ -263,8 +347,29 @@ func parse_message(msg string/*, user User*/) string {
outbytes = append(outbytes, rid_bit...)
outbytes = append(outbytes, url_close...)
lastItem = i
} else if bytes.Equal(msgbytes[i+1:i+5],[]byte("fid-")) {
outbytes = append(outbytes,msgbytes[lastItem:i]...)
i += 5
start := i
fid, int_len := coerce_int_bytes(msgbytes[start:])
i += int_len
if !forum_exists(fid) {
outbytes = append(outbytes,invalid_forum...)
lastItem = i
continue
}
outbytes = append(outbytes, url_open...)
var url_bit []byte = []byte(build_forum_url(fid))
outbytes = append(outbytes, url_bit...)
outbytes = append(outbytes, url_open2...)
var fid_bit []byte = []byte("#fid-" + strconv.Itoa(fid))
outbytes = append(outbytes, fid_bit...)
outbytes = append(outbytes, url_close...)
lastItem = i
} else {
// TO-DO: Forum Link
// TO-DO: Forum Shortcode Link
}
} else if msgbytes[i]=='@' {
//fmt.Println("IN @")

View File

@ -724,6 +724,16 @@ func route_create_reply(w http.ResponseWriter, r *http.Request) {
return
}
// Reload the topic...
err = topics.Load(tid)
if err != nil && err != sql.ErrNoRows {
LocalError("The destination no longer exists",w,r,user)
return
} else if err != nil {
InternalError(err,w,r)
return
}
http.Redirect(w,r,"/topic/" + strconv.Itoa(tid), http.StatusSeeOther)
err = increase_post_user_stats(wcount, user.ID, false, user)
if err != nil {

View File

@ -87,6 +87,14 @@ func SendEmail(email string, subject string, msg string) bool {
return false
}
if smtp_username != "" {
auth := smtp.PlainAuth("",smtp_username,smtp_password,smtp_server)
err = con.Auth(auth)
if err != nil {
return false
}
}
email_data, err := con.Data()
if err != nil {
return false