本文整理匯總了Golang中google/golang.org/appengine/log.Errorf函數的典型用法代碼示例。如果您正苦於以下問題:Golang Errorf函數的具體用法?Golang Errorf怎麽用?Golang Errorf使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。
在下文中一共展示了Errorf函數的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。
示例1: addPhoto
func addPhoto(fName string, id string, req *http.Request) error {
ctx := appengine.NewContext(req)
// DATASTORE
md, err := retrieveDstore(id, req)
if err != nil {
return err
}
md.Pictures = append(md.Pictures, fName)
err = storeDstore(md, req) // removed id in parameter
if err != nil {
log.Errorf(ctx, "ERROR addPhoto storeDstore: %s", err)
return err
}
// MEMCACHE
var mc model
mc, err = retrieveMemc(id, req)
if err != nil {
log.Errorf(ctx, "ERROR addPhoto retrieveMemc: %s", err)
return err
}
mc.Pictures = append(mc.Pictures, fName)
err = storeMemc(mc, req) // removed id in parameter
if err != nil {
log.Errorf(ctx, "ERROR addPhoto storeMemc: %s", err)
return err
}
return nil
}
示例2: Get
func Get(c context.Context, key, def string, values ...interface{}) string {
configLock.Lock()
defer configLock.Unlock()
val, ok := configCache[key]
if ok {
return fmt.Sprintf(val, values...)
}
value := Value{}
dskey := datastore.NewKey(c, ConfigName, key, 0, nil)
err := datastore.Get(c, dskey, &value)
if err == datastore.ErrNoSuchEntity {
value.Val = def
log.Infof(c, "Creating default config for key - %s - default value is - %s", key, value.Val)
_, err = datastore.Put(c, dskey, &value)
if err != nil {
log.Errorf(c, "Error creating default config for key - %s - error is - %v", key, err)
}
return fmt.Sprintf(def, values...) // return default, totally new config setting
}
if err != nil {
log.Errorf(c, "Error fetching config for key - %s - error is - %v", key, err)
return def // error, return the default
}
configCache[key] = value.Val
return fmt.Sprintf(value.Val, values...)
}
示例3: createUser
func createUser(res http.ResponseWriter, req *http.Request, _ httprouter.Params) {
ctx := appengine.NewContext(req)
hashedPass, err := bcrypt.GenerateFromPassword([]byte(req.FormValue("password")), bcrypt.DefaultCost)
if err != nil {
log.Errorf(ctx, "error creating password: %v", err)
http.Error(res, err.Error(), 500)
return
}
user := User{
Email: req.FormValue("email"),
UserName: req.FormValue("userName"),
Password: string(hashedPass),
}
key := datastore.NewKey(ctx, "Users", user.UserName, 0, nil)
key, err = datastore.Put(ctx, key, &user)
if err != nil {
log.Errorf(ctx, "error adding todo: %v", err)
http.Error(res, err.Error(), 500)
return
}
createSession(res, req, user)
// redirect
http.Redirect(res, req, "/", 302)
}
示例4: index
func index(res http.ResponseWriter, req *http.Request) {
ctx := appengine.NewContext(req)
id, err := getID(res, req)
if err != nil {
log.Errorf(ctx, "getID: %s", err)
http.Error(res, err.Error(), http.StatusInternalServerError)
return
}
if req.Method == "POST" {
src, _, err := req.FormFile("data")
if err != nil {
log.Errorf(ctx, "ERROR index req.FormFile: %s", err)
http.Redirect(res, req, `/?id=`+id, http.StatusSeeOther)
return
}
err = uploadPhoto(src, id, req)
if err != nil {
log.Errorf(ctx, "ERROR index uploadPhoto: %s", err)
http.Redirect(res, req, "/logout", http.StatusSeeOther)
return
}
}
m, err := retrieveMemc(id, req)
if err != nil {
log.Errorf(ctx, "ERROR index retrieveMemc: %s", err)
http.Redirect(res, req, "/logout", http.StatusSeeOther)
return
}
tpl.ExecuteTemplate(res, "index.html", m)
}
示例5: handleAdd
func handleAdd(res http.ResponseWriter, req *http.Request) {
ctx := appengine.NewContext(req)
var err error
if req.Method == "POST" {
name := strings.TrimSpace(req.FormValue("name"))
summary, err := getHTML(ctx, req.FormValue("summary"))
if err != nil {
http.Error(res, "Server error", http.StatusInternalServerError)
log.Errorf(ctx, "%v\n", err)
return
}
mov := &movie{
Name: name,
Summary: summary,
URL: strings.ToLower(strings.Replace(name, " ", "", -1)),
}
err = addMovie(ctx, mov)
if err != nil {
http.Error(res, "Server error", http.StatusInternalServerError)
log.Errorf(ctx, "%v\n", err)
return
}
http.Redirect(res, req, "/", http.StatusSeeOther)
return
}
err = tpl.ExecuteTemplate(res, "addMovie", nil)
if err != nil {
http.Error(res, "Server error", http.StatusInternalServerError)
log.Errorf(ctx, "%v\n", err)
return
}
}
示例6: handleUpdate
func handleUpdate(w http.ResponseWriter, r *http.Request) {
c := appengine.NewContext(r)
var (
d int
day time.Weekday
err error
)
// Check if there is a signed in user.
u := currentUser(r)
if u == nil {
aelog.Errorf(c, "No signed in user for updating")
goto out
}
// Validate XSRF token first.
if !xsrftoken.Valid(r.PostFormValue(xsrfTokenName), xsrfKey, u.ID, updateURL) {
aelog.Errorf(c, "XSRF token validation failed")
goto out
}
// Extract the new favorite weekday.
d, err = strconv.Atoi(r.PostFormValue(favoriteName))
if err != nil {
aelog.Errorf(c, "Failed to extract new favoriate weekday: %s", err)
goto out
}
day = time.Weekday(d)
if day < time.Sunday || day > time.Saturday {
aelog.Errorf(c, "Got wrong value for favorite weekday: %d", d)
}
// Update the favorite weekday.
updateWeekdayForUser(r, u, day)
out:
// Redirect to home page to show the update result.
http.Redirect(w, r, homeURL, http.StatusFound)
}
示例7: handleIndex
func handleIndex(res http.ResponseWriter, req *http.Request) {
if req.URL.Path != "/" {
handleMovieDetails(res, req)
return
}
ctx := appengine.NewContext(req)
data := struct {
Movies []movie
}{}
m, err := getRecentMovies(ctx, 15)
if err != nil {
http.Error(res, "Server error", http.StatusInternalServerError)
log.Errorf(ctx, "%v\n", err)
return
}
data.Movies = m
err = tpl.ExecuteTemplate(res, "index", data)
if err != nil {
http.Error(res, "Server error", http.StatusInternalServerError)
log.Errorf(ctx, "%v\n", err)
return
}
}
示例8: user
func user(res http.ResponseWriter, req *http.Request, ps httprouter.Params) {
ctx := appengine.NewContext(req)
user := User{UserName: ps.ByName("user")}
//get tweets
tweets, err := getTweets(req, &user)
if err != nil {
log.Errorf(ctx, "error getting tweets: %v", err)
http.Error(res, err.Error(), 500)
return
}
// get session
memItem, err := getSession(req)
var sd SessionData
if err == nil {
// logged in
json.Unmarshal(memItem.Value, &sd)
sd.LoggedIn = true
sd.ViewingUser = user.UserName
sd.FollowingUser, err = following(sd.UserName, user.UserName, req)
if err != nil {
log.Errorf(ctx, "error running following query: %v", err)
http.Error(res, err.Error(), 500)
return
}
}
sd.Tweets = tweets
tpl.ExecuteTemplate(res, "user.html", &sd)
}
示例9: fing
func fing(res http.ResponseWriter, req *http.Request, _ httprouter.Params) {
ctx := appengine.NewContext(req)
// get session
memItem, err := getSession(req)
if err != nil {
log.Infof(ctx, "Attempt to see following from logged out user")
http.Error(res, "You must be logged in", http.StatusForbidden)
return
}
var sd SessionData
if err == nil {
// logged in
json.Unmarshal(memItem.Value, &sd)
sd.LoggedIn = true
}
// declare a variable of type user
// initialize user with values from memcache item
var user User
json.Unmarshal(memItem.Value, &user)
// Get followees
// get the datastore key for the follower
followerKey := datastore.NewKey(ctx, "Users", user.UserName, 0, nil)
var XF []F
_, err = datastore.NewQuery("Follows").Ancestor(followerKey).Project("Following").GetAll(ctx, &XF)
log.Errorf(ctx, "here is type %T \n and value %v", XF, XF)
if err != nil {
log.Errorf(ctx, "error getting followees: %v", err)
http.Error(res, err.Error(), 500)
return
}
sd.Following = XF
tpl.ExecuteTemplate(res, "follow.html", &sd)
}
示例10: handleCron
func handleCron(w http.ResponseWriter, r *http.Request) *appError {
// X-Appengine-Cron: true
c := appengine.NewContext(r)
a, err := LoadMagazines(c)
if err != nil {
return &appError{
Error: err,
Message: "failed to load",
Code: http.StatusInternalServerError,
}
}
client := urlfetch.Client(c)
for _, m := range a {
f, err := fetchFeed(client, m.URL)
if err != nil {
log.Errorf(c, "fetch url: %v", err)
continue
}
if err = SendArticles(c, m, f); err != nil {
log.Errorf(c, "send article: %v", err)
continue
}
}
return nil
}
示例11: textMessageHandler
func textMessageHandler(w http.ResponseWriter, r *http.Request) {
ctx := appengine.NewContext(r)
to := r.FormValue("to")
text := r.FormValue("text")
log.Debugf(ctx, "to: %s, text: %s.", to, text)
chi, _ := strconv.ParseInt(os.Getenv("CHANNEL_ID"), 10, 64)
chs := os.Getenv("CHANNEL_SECRET")
mid := os.Getenv("MID")
client := urlfetch.Client(ctx)
bot, err := linebot.NewClient(chi, chs, mid, linebot.WithHTTPClient(client))
if err != nil {
log.Errorf(ctx, "Client initialization failure. to: %s, text: %s, context: %s", to, text, err.Error())
w.WriteHeader(http.StatusInternalServerError)
return
}
res, err := bot.SendText([]string{to}, text)
if err != nil {
log.Errorf(ctx, "Message Send Failed. to: %s, text: %s, context: %s", to, text, err.Error())
w.WriteHeader(http.StatusInternalServerError)
return
}
log.Infof(ctx, "Message send succeed. MessageID: %s, to: %s, text: %s", res.MessageID, to, text)
w.WriteHeader(http.StatusOK)
}
示例12: makeCookie
func makeCookie(m model, req *http.Request) (*http.Cookie, error) {
ctx := appengine.NewContext(req)
// DATASTORE
err := storeDstore(m, req)
if err != nil {
log.Errorf(ctx, "ERROR makeCookie storeDstore: %s", err)
return nil, err
}
// MEMCACHE
err = storeMemc(m, req)
if err != nil {
log.Errorf(ctx, "ERROR makeCookie storeMemc: %s", err)
return nil, err
}
// COOKIE
cookie := &http.Cookie{
Name: "session-id",
Value: m.ID,
// Secure: true,
HttpOnly: true,
}
return cookie, nil
}
示例13: copyFile
//function copyFile takes in the string fileName and reads that
//fileName in the system then writes it in the gcs in short makes
//a copy of the file to gcs
func (a *app) copyFile(fileName string) {
writer := a.bucket.Object(fileName).NewWriter(a.ctx)
writer.ACL = []storage.ACLRule{
{storage.AllUsers, storage.RoleReader},
}
writer.ContentType = "image/jpg"
//read file from folders img and photos
b, err := ioutil.ReadFile(fileName)
if err != nil {
log.Errorf(a.ctx, "Error in copyFile: ", err)
return
}
//writes the read bytes to gcs bucket.
_, err = writer.Write(b)
if err != nil {
log.Errorf(a.ctx, "createFile: unable to write data to bucket")
return
}
err = writer.Close()
if err != nil {
log.Errorf(a.ctx, "createFile Close")
return
}
}
示例14: statFiles
func (d *demo) statFiles() {
io.WriteString(d.res, "\nRETRIEVING FILE STATS\n")
client, err := storage.NewClient(d.ctx)
if err != nil {
log.Errorf(d.ctx, "%v", err)
return
}
defer client.Close()
// create a query
q := storage.Query{
MaxResults: 2,
}
// instead of nil
// now passing in a *storage.Query
objs, err := client.Bucket(gcsBucket).List(d.ctx, &q)
if err != nil {
log.Errorf(d.ctx, "%v", err)
return
}
for _, v := range objs.Results {
d.statFile(v.Name)
}
}
示例15: PrimaryPublicCertificates
// PrimaryPublicCertificates returns primary's PublicCertificates.
func PrimaryPublicCertificates(c context.Context, primaryURL string) (*PublicCertificates, error) {
cacheKey := fmt.Sprintf("pub_certs:%s", primaryURL)
var pubCerts []byte
setCache := false
item, err := memcache.Get(c, cacheKey)
if err != nil {
setCache = true
if err != memcache.ErrCacheMiss {
log.Warningf(c, "failed to get cert from cache: %v", err)
}
pubCerts, err = downloadCert(urlfetch.Client(c), primaryURL)
if err != nil {
log.Errorf(c, "failed to download cert: %v", err)
return nil, err
}
} else {
pubCerts = item.Value
}
pc := &PublicCertificates{}
if err = json.Unmarshal(pubCerts, pc); err != nil {
log.Errorf(c, "failed to unmarshal cert: %v %v", string(pubCerts), err)
return nil, err
}
if setCache {
err = memcache.Set(c, &memcache.Item{
Key: cacheKey,
Value: pubCerts,
Expiration: time.Hour,
})
if err != nil {
log.Warningf(c, "failed to set cert to cache: %v", err)
}
}
return pc, nil
}