aboutsummaryrefslogtreecommitdiffstats
path: root/routers/api/packages/helper/helper.go
blob: 27d4e6ffdc6f3e373ee7a54d6689b0da35efca25 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
// Copyright 2021 The Gitea Authors. All rights reserved.
// SPDX-License-Identifier: MIT

package helper

import (
	"fmt"
	"io"
	"net/http"
	"net/url"

	packages_model "code.gitea.io/gitea/models/packages"
	"code.gitea.io/gitea/modules/log"
	"code.gitea.io/gitea/modules/setting"
	"code.gitea.io/gitea/services/context"
)

// ProcessErrorForUser logs the error and returns a user-error message for the end user.
// If the status is http.StatusInternalServerError, the message is stripped for non-admin users in production.
func ProcessErrorForUser(ctx *context.Context, status int, errObj any) string {
	var message string
	if err, ok := errObj.(error); ok {
		message = err.Error()
	} else if errObj != nil {
		message = fmt.Sprint(errObj)
	}

	if status == http.StatusInternalServerError {
		log.Log(2, log.ERROR, "Package registry API internal error: %d %s", status, message)
		if setting.IsProd && (ctx.Doer == nil || !ctx.Doer.IsAdmin) {
			message = "internal server error"
		}
		return message
	}

	log.Log(2, log.DEBUG, "Package registry API user error: %d %s", status, message)
	return message
}

// ServePackageFile the content of the package file
// If the url is set it will redirect the request, otherwise the content is copied to the response.
func ServePackageFile(ctx *context.Context, s io.ReadSeekCloser, u *url.URL, pf *packages_model.PackageFile, forceOpts ...*context.ServeHeaderOptions) {
	if u != nil {
		ctx.Redirect(u.String())
		return
	}

	defer s.Close()

	var opts *context.ServeHeaderOptions
	if len(forceOpts) > 0 {
		opts = forceOpts[0]
	} else {
		opts = &context.ServeHeaderOptions{
			Filename:     pf.Name,
			LastModified: pf.CreatedUnix.AsLocalTime(),
		}
	}

	ctx.ServeContent(s, opts)
}