2016-08-23 11:23:25 +00:00
var fs = require ( 'fs-extra' ) ;
var uuid = require ( 'uuid' ) ;
2016-08-23 15:50:30 +00:00
var path = require ( 'path' ) ;
2016-09-09 07:51:10 +00:00
var cloudscraper = require ( 'cloudscraper' ) ;
2016-09-12 22:39:21 +00:00
var readChunk = require ( 'read-chunk' ) ;
var fileType = require ( 'file-type' ) ;
var request = require ( 'request' ) ;
var ytdl = require ( 'ytdl-core' ) ;
var Readable = require ( 'stream' ) . Readable ;
2016-09-09 07:51:10 +00:00
var cfg = require ( '../../cfg/main.json' ) ;
2016-08-23 11:23:25 +00:00
2016-09-09 11:18:03 +00:00
module . exports = ( bot , lib ) => {
lib . trigger . add ( {
2016-08-23 11:23:25 +00:00
name : 'parser' ,
2016-08-24 20:02:20 +00:00
call : /https?:\/\/[\w-]+(\.[\w-]+)+\.?(:\d+)?(\/\S*)?/gi ,
2016-08-23 11:23:25 +00:00
level : 0 ,
2016-08-24 07:55:40 +00:00
active : 1 ,
2016-08-23 11:23:25 +00:00
func : ( e ) => {
2016-09-08 15:46:14 +00:00
if ( e . channel . getName ( ) == '#f0ck' || e . channel . getName ( ) == '#kbot-dev' ) {
2016-08-23 17:36:16 +00:00
if ( ! e . message . match ( /\!ignore$/ ) ) {
var tmp = e . message . match ( /https?:\/\/[\w-]+(\.[\w-]+)+\.?(:\d+)?(\/\S*)?/gi ) ; // get links
tmp . forEach ( ( entry , i , a ) => {
2016-08-24 20:21:02 +00:00
if ( ! entry . match ( /f0ck\.me/i ) ) {
2016-09-12 22:39:21 +00:00
getLink ( entry , ( cb ) => {
if ( cb . success === true ) {
fs . move ( cb . file , cb . file + '.' + cb . info . ext , ( err ) => {
if ( ! err ) {
bot . whois ( e . user . getNick ( ) , e . network , ( err , cbgu ) => {
lib . sql . query ( "insert into `f0ck`.`items` (`src`,`dest`,`mime`,`size`,`checksum`,`username`,`userchannel`,`usernetwork`,`stamp`,`active`,`thumb`) values (?,?,?,?,?,?,?,?,?,?,?)" , [
entry ,
cb . file + '.' + cb . info . ext ,
cb . info . mime ,
cb . size ,
cb . checksum ,
cbgu [ 'nick' ] ,
e . channel . getName ( ) ,
e . network ,
Math . floor ( new Date ( ) / 1000 ) ,
0 ,
( cb . info . thumb !== null ) ? cb . info . thumb : ''
] ) . on ( 'result' , ( result ) => {
lib . generateThumbs ( ) ;
e . reply ( "https://f0ck.me/" + result . insertId + " - " + cb . info . title + " (" + cb . info . mime + ", ~" + lib . formatSize ( cb . size ) + ") from " + cbgu [ 'nick' ] + " (" + cbgu [ 'username' ] + "@" + cbgu [ 'hostname' ] + ")" ) ;
} ) . on ( 'error' , ( msg ) => {
e . reply ( msg ) ;
} ) ;
} ) ;
2016-09-09 07:51:10 +00:00
}
2016-08-23 11:23:25 +00:00
} ) ;
2016-08-24 20:21:02 +00:00
}
else
2016-09-12 22:39:21 +00:00
if ( cb . msg != '' )
e . reply ( cb . msg ) ;
2016-08-24 20:21:02 +00:00
} ) ;
}
2016-08-23 11:23:25 +00:00
} ) ;
2016-08-23 17:36:16 +00:00
}
2016-08-23 11:23:25 +00:00
}
} ,
desc : 'muh'
} ) ;
2016-09-12 22:39:21 +00:00
var getLink = ( url , cb ) => {
var yt = /https?:\/\/(www\.)?(yotu\.be\/|youtube\.com\/)((.+\/)?(watch(\?v=|.+&v=))?(v=)?)([\w_-]{11})(&.+)?/gi ;
var sc = /https?:\/\/(www\.)?(soundcloud\.com|snd\.sc)(\/\S*)(\/\S*)/gi ;
lib . checkRepost ( url , ( cbcr ) => {
if ( cbcr === true ) {
var tmpdest = uuid . v1 ( ) . split ( '-' ) [ 0 ] ;
var dat = fs . createWriteStream ( './b/' + tmpdest ) ;
var info ;
if ( url . match ( yt ) ) { // ytdl
ytdl . getInfo ( url , ( err , inf ) => {
if ( ! err ) {
var title = inf . title ;
var iurl = inf . iurl ;
try {
ytdl . downloadFromInfo ( inf , { filter : ( format ) => { return format . container === 'webm' ; } } )
. on ( 'response' , ( res ) => {
if ( res . headers [ 'content-length' ] > cfg . maxFileSize ) {
res . destroy ( ) ;
dat . close ( ) ;
fs . unlinkSync ( './b/' + tmpdest ) ;
cb ( { success : false , msg : 'f0ck! your file is too big (~' + lib . formatSize ( res . headers [ 'content-length' ] ) + '), max ' + lib . formatSize ( cfg . maxFileSize ) + ' allowed' } ) ;
}
else {
info = {
type : 'youtube' ,
title : title ,
mime : 'video/webm' ,
ext : 'webm' ,
thumb : iurl
} ;
}
} )
. on ( 'error' , ( err ) => {
dat . close ( ) ;
fs . unlinkSync ( './b/' + tmpdest ) ;
cb ( { success : false , msg : ex } ) ;
} )
. pipe ( dat ) ;
}
catch ( ex ) {
dat . close ( ) ;
fs . unlinkSync ( './b/' + tmpdest ) ;
cb ( { success : false , msg : ex } ) ;
}
}
} ) ;
}
else if ( url . match ( sc ) ) { // scdl
request ( 'https://api.soundcloud.com/resolve.json?client_id=' + cfg . scclientid + '&url=' + url , ( err , res , body ) => {
if ( ! err && res . statusCode === 200 ) {
var data = JSON . parse ( body ) ;
request ( data . stream _url + ( ( data . stream _url . indexOf ( '?' ) === - 1 ) ? '?' : '&' ) + 'client_id=' + cfg . scclientid )
. pipe ( dat ) ;
info = {
type : 'soundcloud' ,
title : data . title ,
mime : 'audio/mpeg' ,
ext : 'mp3' ,
thumb : ( data . artwork _url !== null ) ? data . artwork _url . replace ( 'large.jpg' , 't300x300.jpg' ) : null
} ;
}
else {
dat . close ( ) ;
fs . unlinkSync ( './b/' + tmpdest ) ;
2016-09-13 09:40:04 +00:00
cb ( { success : false , msg : 'f0ck sc-api' } ) ;
2016-09-12 22:39:21 +00:00
}
} ) ;
}
else { // various
cloudscraper . request ( {
method : 'GET' ,
url : url ,
encoding : null ,
} ,
( err , res , data ) => {
if ( ! err ) {
var type = res . headers [ 'content-type' ] ;
var length = res . headers [ 'content-length' ] ;
if ( cfg . allowedMimes . hasOwnProperty ( type ) ) {
if ( length <= cfg . maxFileSize ) {
var s = new Readable
s . push ( data ) ;
s . push ( null ) ;
s . pipe ( dat ) ;
info = {
type : 'other' ,
title : path . parse ( url ) . base ,
mime : type ,
ext : cfg . allowedMimes [ type ] ,
thumb : null
} ;
}
else {
dat . close ( ) ;
fs . unlinkSync ( './b/' + tmpdest ) ;
cb ( { success : false , msg : 'f0ck! your file is too big (~' + lib . formatSize ( length ) + '), max ' + lib . formatSize ( cfg . maxFileSize ) + ' allowed' } ) ;
}
}
else {
dat . close ( ) ;
fs . unlinkSync ( './b/' + tmpdest ) ;
cb ( { success : false , msg : '' } ) ;
}
}
else {
dat . close ( ) ;
fs . unlinkSync ( './b/' + tmpdest ) ;
cb ( { success : false , msg : err } ) ;
}
} ) ;
}
dat
. on ( 'finish' , ( ) => {
var size = dat . bytesWritten ;
dat . close ( ) ;
if ( size > cfg . maxFileSize )
cb ( { success : false , msg : 'f0ck! your file is too big (~' + lib . formatSize ( size ) + '), max ' + lib . formatSize ( cfg . maxFileSize ) + ' allowed' } ) ;
else {
lib . getCheckSum ( './b/' + tmpdest , ( cbcs ) => {
lib . checkRepostCheckSum ( cbcs , ( cbcrcs ) => {
if ( cbcrcs === true ) {
var mime = fileType ( readChunk . sync ( './b/' + tmpdest , 0 , 262 ) ) ;
if ( cfg . allowedMimes . hasOwnProperty ( mime . mime ) || info . type === 'soundcloud' )
cb ( { success : true , info : info , size : size , file : './b/' + tmpdest , checksum : cbcs } ) ;
else
cb ( { success : false , msg : 'lol, go f0ck yourself (' + mime + ')' } ) ;
}
else
cb ( { success : false , msg : 'repost motherf0cker: https://f0ck.me/' + cbcrcs } ) ;
} ) ;
} ) ;
}
} )
. on ( 'error' , ( err ) => {
fs . unlinkSync ( './b/' + tmpdest ) ;
cb ( { success : false , msg : err } ) ;
} ) ;
}
else
cb ( { success : false , msg : 'repost motherf0cker: https://f0ck.me/' + cbcr } ) ;
} ) ;
} ;
2016-08-23 11:23:25 +00:00
} ;