1
0
Fork 0
mirror of https://github.com/vbatts/imgsrv.git synced 2024-11-24 00:55:41 +00:00

cleanup: more separating into files

This commit is contained in:
Vincent Batts 2013-02-08 23:43:39 -05:00
parent e4ea30a89b
commit f05e47e0a1
5 changed files with 129 additions and 116 deletions

75
client.go Normal file
View file

@ -0,0 +1,75 @@
package main
import (
"bufio"
"crypto/tls"
"io/ioutil"
"log"
"mime"
"net/http"
"os"
"path/filepath"
"time"
)
func PutFileFromPath(host, filename string) (path string, err error) {
ext := filepath.Ext(filename)
file, err := os.Open(filename)
if (err != nil) {
return
}
resp, err := http.Post(host, mime.TypeByExtension(ext) , bufio.NewReader(file))
if (err != nil) {
return
}
bytes, err := ioutil.ReadAll(resp.Body)
if (err != nil) {
return
}
return string(bytes), nil
}
func FetchFileFromURL(url string) (filename string, err error) {
var t time.Time
tr := &http.Transport{
TLSClientConfig: &tls.Config{ InsecureSkipVerify: true },
}
client := &http.Client{
//CheckRedirect: redirectPolicyFunc,
Transport: tr,
}
resp, err := client.Get(url)
defer resp.Body.Close()
if (err != nil) {
return
}
mtime := resp.Header.Get("last-modified")
if (len(mtime) > 0) {
t, err = time.Parse(http.TimeFormat, mtime)
if (err != nil) {
return
}
} else {
log.Println("Last-Modified not present. Using current time")
t = time.Now()
}
_, url_filename := filepath.Split(url)
log.Println(resp)
bytes, err := ioutil.ReadAll(resp.Body)
if (err != nil) {
return
}
err = ioutil.WriteFile(filepath.Join(os.TempDir(), url_filename), bytes, 0644)
if (err != nil) {
return
}
err = os.Chtimes(filepath.Join(os.TempDir(), url_filename), t, t)
// lastly, return
return filepath.Join(os.TempDir(), url_filename), nil
}

3
get.go
View file

@ -1,6 +1,7 @@
package main package main
import ( import (
"math/rand"
"labix.org/v2/mgo/bson" "labix.org/v2/mgo/bson"
) )
@ -15,7 +16,7 @@ func GetFileByFilename(filename string) (this_file File, err error) {
} }
func GetFileRandom() (this_file File, err error) { func GetFileRandom() (this_file File, err error) {
r := rand64() r := rand.Int63()
err = gfs.Find(bson.M{"random": bson.M{"$gt" : r } }).One(&this_file) err = gfs.Find(bson.M{"random": bson.M{"$gt" : r } }).One(&this_file)
if (err != nil) { if (err != nil) {
return this_file, err return this_file, err

35
has.go Normal file
View file

@ -0,0 +1,35 @@
package main
import (
"labix.org/v2/mgo/bson"
)
/* Check whether this File filename is on Mongo */
func HasFileByFilename(filename string) (exists bool, err error) {
c, err := gfs.Find(bson.M{"filename": filename}).Count()
if (err != nil) {
return false, err
}
exists = (c > 0)
return exists, nil
}
func HasFileByMd5(md5 string) (exists bool, err error) {
c, err := gfs.Find(bson.M{"md5": md5 }).Count()
if (err != nil) {
return false, err
}
exists = (c > 0)
return exists, nil
}
func HasFileByKeyword(keyword string) (exists bool, err error) {
c, err := gfs.Find(bson.M{"metadata": bson.M{"keywords": keyword} }).Count()
if (err != nil) {
return false, err
}
exists = (c > 0)
return exists, nil
}

130
imgsrv.go
View file

@ -8,26 +8,22 @@ package main
*/ */
import ( import (
"log" "crypto/md5"
"labix.org/v2/mgo"
"labix.org/v2/mgo/bson"
"net/http"
"flag" "flag"
"fmt" "fmt"
"path/filepath"
"os"
"strings"
"time"
//"errors"
"mime"
"bufio"
"net/url"
"crypto/tls"
"crypto/md5"
"hash/adler32" "hash/adler32"
"io" "io"
"io/ioutil" "labix.org/v2/mgo"
"labix.org/v2/mgo/bson"
"log"
"math/rand" "math/rand"
"mime"
"net/http"
"net/url"
"os"
"path/filepath"
"strings"
"time"
) )
var ( var (
@ -76,100 +72,6 @@ type File struct {
ContentType string "contentType,omitempty" ContentType string "contentType,omitempty"
} }
func rand64() int64 {
return rand.Int63()
}
/* Check whether this File filename is on Mongo */
func hasFileByFilename(filename string) (exists bool, err error) {
c, err := gfs.Find(bson.M{"filename": filename}).Count()
if (err != nil) {
return false, err
}
exists = (c > 0)
return exists, nil
}
func hasFileByMd5(md5 string) (exists bool, err error) {
c, err := gfs.Find(bson.M{"md5": md5 }).Count()
if (err != nil) {
return false, err
}
exists = (c > 0)
return exists, nil
}
func hasFileByKeyword(keyword string) (exists bool, err error) {
c, err := gfs.Find(bson.M{"metadata": bson.M{"keywords": keyword} }).Count()
if (err != nil) {
return false, err
}
exists = (c > 0)
return exists, nil
}
func putFileFromPath(host, filename string) (path string, err error) {
ext := filepath.Ext(filename)
file, err := os.Open(filename)
if (err != nil) {
return
}
resp, err := http.Post(host, mime.TypeByExtension(ext) , bufio.NewReader(file))
//defer resp.Body.Close()
if (err != nil) {
return
}
bytes, err := ioutil.ReadAll(resp.Body)
if (err != nil) {
return
}
return string(bytes), nil
}
func fetchFileFromURL(url string) (filename string, err error) {
var t time.Time
tr := &http.Transport{
TLSClientConfig: &tls.Config{ InsecureSkipVerify: true },
}
client := &http.Client{
//CheckRedirect: redirectPolicyFunc,
Transport: tr,
}
resp, err := client.Get(url)
defer resp.Body.Close()
if (err != nil) {
return
}
mtime := resp.Header.Get("last-modified")
if (len(mtime) > 0) {
t, err = time.Parse(http.TimeFormat, mtime)
if (err != nil) {
return
}
} else {
log.Println("Last-Modified not present. Using current time")
t = time.Now()
}
_, url_filename := filepath.Split(url)
log.Println(resp)
bytes, err := ioutil.ReadAll(resp.Body)
if (err != nil) {
return
}
err = ioutil.WriteFile(filepath.Join(os.TempDir(), url_filename), bytes, 0644)
if (err != nil) {
return
}
err = os.Chtimes(filepath.Join(os.TempDir(), url_filename), t, t)
// lastly, return
return filepath.Join(os.TempDir(), url_filename), nil
}
/* return a <a href/> for a given filename /* return a <a href/> for a given filename
and root is the relavtive base of the explicit link. and root is the relavtive base of the explicit link.
@ -333,7 +235,7 @@ func routeFilesPOST(w http.ResponseWriter, r *http.Request) {
var filename string var filename string
info := Info{ info := Info{
Ip: r.RemoteAddr, Ip: r.RemoteAddr,
Random: rand64(), Random: rand.Int63(),
} }
if (len(uriChunks) == 2 && len(uriChunks[1]) != 0) { if (len(uriChunks) == 2 && len(uriChunks[1]) != 0) {
@ -369,7 +271,7 @@ func routeFilesPOST(w http.ResponseWriter, r *http.Request) {
} }
} }
exists, err := hasFileByFilename(filename) exists, err := HasFileByFilename(filename)
if (err == nil && !exists) { if (err == nil && !exists) {
file, err := gfs.Create(filename) file, err := gfs.Create(filename)
if (err != nil) { if (err != nil) {
@ -416,7 +318,7 @@ func routeFilesDELETE(w http.ResponseWriter, r *http.Request) {
return return
} else if (len(uriChunks) == 2 && len(uriChunks[1]) == 0) { } else if (len(uriChunks) == 2 && len(uriChunks[1]) == 0) {
} }
exists, err := hasFileByFilename(uriChunks[1]) exists, err := HasFileByFilename(uriChunks[1])
if (err != nil) { if (err != nil) {
serverErr(w,r,err) serverErr(w,r,err)
return return
@ -710,7 +612,7 @@ func main() {
loadConfiguration(ConfigFile) loadConfiguration(ConfigFile)
if (len(FetchUrl) > 0) { if (len(FetchUrl) > 0) {
file, err := fetchFileFromURL(FetchUrl) file, err := FetchFileFromURL(FetchUrl)
if (err != nil) { if (err != nil) {
log.Println(err) log.Println(err)
return return
@ -741,7 +643,7 @@ func main() {
return return
} }
log.Printf("POSTing: %s\n", url.String()) log.Printf("POSTing: %s\n", url.String())
url_path, err := putFileFromPath(url.String(), PutFile) url_path, err := PutFileFromPath(url.String(), PutFile)
if (err != nil) { if (err != nil) {
log.Println(err) log.Println(err)
return return