Add support for gitea-pages-allowall repo topic tag
If a repo has been tagged with gitea-pages-allowall we don't need an extra gitea-pages branch with a toml configuration. This makes it easier for repos that can just expose every branch
This commit is contained in:
		
							parent
							
								
									e46079d2b1
								
							
						
					
					
						commit
						f9a7e98702
					
				
							
								
								
									
										15
									
								
								gitea.go
									
									
									
									
									
								
							
							
						
						
									
										15
									
								
								gitea.go
									
									
									
									
									
								
							@ -26,11 +26,12 @@ func parseCaddyfile(h httpcaddyfile.Helper) (caddyhttp.MiddlewareHandler, error)
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
// Middleware implements gitea plugin.
 | 
					// Middleware implements gitea plugin.
 | 
				
			||||||
type Middleware struct {
 | 
					type Middleware struct {
 | 
				
			||||||
	Client     *gitea.Client `json:"-"`
 | 
						Client             *gitea.Client `json:"-"`
 | 
				
			||||||
	Server     string        `json:"server,omitempty"`
 | 
						Server             string        `json:"server,omitempty"`
 | 
				
			||||||
	Token      string        `json:"token,omitempty"`
 | 
						Token              string        `json:"token,omitempty"`
 | 
				
			||||||
	GiteaPages string        `json:"gitea_pages,omitempty"`
 | 
						GiteaPages         string        `json:"gitea_pages,omitempty"`
 | 
				
			||||||
	Domain     string        `json:"domain,omitempty"`
 | 
						GiteaPagesAllowAll string        `json:"gitea_pages_allowall,omitempty"`
 | 
				
			||||||
 | 
						Domain             string        `json:"domain,omitempty"`
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
// CaddyModule returns the Caddy module information.
 | 
					// CaddyModule returns the Caddy module information.
 | 
				
			||||||
@ -44,7 +45,7 @@ func (Middleware) CaddyModule() caddy.ModuleInfo {
 | 
				
			|||||||
// Provision provisions gitea client.
 | 
					// Provision provisions gitea client.
 | 
				
			||||||
func (m *Middleware) Provision(ctx caddy.Context) error {
 | 
					func (m *Middleware) Provision(ctx caddy.Context) error {
 | 
				
			||||||
	var err error
 | 
						var err error
 | 
				
			||||||
	m.Client, err = gitea.NewClient(m.Server, m.Token, m.GiteaPages)
 | 
						m.Client, err = gitea.NewClient(m.Server, m.Token, m.GiteaPages, m.GiteaPagesAllowAll)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	return err
 | 
						return err
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
@ -65,6 +66,8 @@ func (m *Middleware) UnmarshalCaddyfile(d *caddyfile.Dispenser) error {
 | 
				
			|||||||
				d.Args(&m.Token)
 | 
									d.Args(&m.Token)
 | 
				
			||||||
			case "gitea_pages":
 | 
								case "gitea_pages":
 | 
				
			||||||
				d.Args(&m.GiteaPages)
 | 
									d.Args(&m.GiteaPages)
 | 
				
			||||||
 | 
								case "gitea_pages_allowall":
 | 
				
			||||||
 | 
									d.Args(&m.GiteaPagesAllowAll)
 | 
				
			||||||
			case "domain":
 | 
								case "domain":
 | 
				
			||||||
				d.Args(&m.Domain)
 | 
									d.Args(&m.Domain)
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
 | 
				
			|||||||
@ -15,35 +15,37 @@ import (
 | 
				
			|||||||
)
 | 
					)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
type Client struct {
 | 
					type Client struct {
 | 
				
			||||||
	serverURL  string
 | 
						serverURL          string
 | 
				
			||||||
	token      string
 | 
						token              string
 | 
				
			||||||
	giteapages string
 | 
						giteapages         string
 | 
				
			||||||
	gc         *gclient.Client
 | 
						giteapagesAllowAll string
 | 
				
			||||||
 | 
						gc                 *gclient.Client
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
func NewClient(serverURL, token, giteapages string) (*Client, error) {
 | 
					func NewClient(serverURL, token, giteapages, giteapagesAllowAll string) (*Client, error) {
 | 
				
			||||||
	if giteapages == "" {
 | 
						if giteapages == "" {
 | 
				
			||||||
		giteapages = "gitea-pages"
 | 
							giteapages = "gitea-pages"
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						if giteapagesAllowAll == "" {
 | 
				
			||||||
 | 
							giteapagesAllowAll = "gitea-pages-allowall"
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	gc, err := gclient.NewClient(serverURL, gclient.SetToken(token), gclient.SetGiteaVersion(""))
 | 
						gc, err := gclient.NewClient(serverURL, gclient.SetToken(token), gclient.SetGiteaVersion(""))
 | 
				
			||||||
	if err != nil {
 | 
						if err != nil {
 | 
				
			||||||
		return nil, err
 | 
							return nil, err
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	return &Client{
 | 
						return &Client{
 | 
				
			||||||
		serverURL:  serverURL,
 | 
							serverURL:          serverURL,
 | 
				
			||||||
		token:      token,
 | 
							token:              token,
 | 
				
			||||||
		gc:         gc,
 | 
							gc:                 gc,
 | 
				
			||||||
		giteapages: giteapages,
 | 
							giteapages:         giteapages,
 | 
				
			||||||
 | 
							giteapagesAllowAll: giteapagesAllowAll,
 | 
				
			||||||
	}, nil
 | 
						}, nil
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
func (c *Client) Open(name, ref string) (fs.File, error) {
 | 
					func (c *Client) Open(name, ref string) (fs.File, error) {
 | 
				
			||||||
	if ref == "" {
 | 
					 | 
				
			||||||
		ref = c.giteapages
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	owner, repo, filepath := splitName(name)
 | 
						owner, repo, filepath := splitName(name)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	// if repo is empty they want to have the gitea-pages repo
 | 
						// if repo is empty they want to have the gitea-pages repo
 | 
				
			||||||
@ -58,7 +60,8 @@ func (c *Client) Open(name, ref string) (fs.File, error) {
 | 
				
			|||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	// we need to check if the repo exists (and allows access)
 | 
						// we need to check if the repo exists (and allows access)
 | 
				
			||||||
	if !c.allowsPages(owner, repo) {
 | 
						limited, allowall := c.allowsPages(owner, repo)
 | 
				
			||||||
 | 
						if !limited && !allowall {
 | 
				
			||||||
		// if we're checking the gitea-pages and it doesn't exist, return 404
 | 
							// if we're checking the gitea-pages and it doesn't exist, return 404
 | 
				
			||||||
		if repo == c.giteapages && !c.hasRepoBranch(owner, repo, c.giteapages) {
 | 
							if repo == c.giteapages && !c.hasRepoBranch(owner, repo, c.giteapages) {
 | 
				
			||||||
			return nil, fs.ErrNotExist
 | 
								return nil, fs.ErrNotExist
 | 
				
			||||||
@ -69,7 +72,12 @@ func (c *Client) Open(name, ref string) (fs.File, error) {
 | 
				
			|||||||
		filepath = repo
 | 
							filepath = repo
 | 
				
			||||||
		repo = c.giteapages
 | 
							repo = c.giteapages
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		if !c.allowsPages(owner, repo) || !c.hasRepoBranch(owner, repo, c.giteapages) {
 | 
							if ref == "" {
 | 
				
			||||||
 | 
								ref = c.giteapages
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							limited, allowall = c.allowsPages(owner, repo)
 | 
				
			||||||
 | 
							if !limited && !allowall || !c.hasRepoBranch(owner, repo, c.giteapages) {
 | 
				
			||||||
			return nil, fs.ErrNotExist
 | 
								return nil, fs.ErrNotExist
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
@ -79,7 +87,7 @@ func (c *Client) Open(name, ref string) (fs.File, error) {
 | 
				
			|||||||
	if err := c.readConfig(owner, repo); err != nil {
 | 
						if err := c.readConfig(owner, repo); err != nil {
 | 
				
			||||||
		// we don't need a config for gitea-pages
 | 
							// we don't need a config for gitea-pages
 | 
				
			||||||
		// no config is only exposing the gitea-pages branch
 | 
							// no config is only exposing the gitea-pages branch
 | 
				
			||||||
		if repo != c.giteapages {
 | 
							if repo != c.giteapages && !allowall {
 | 
				
			||||||
			return nil, err
 | 
								return nil, err
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -90,7 +98,7 @@ func (c *Client) Open(name, ref string) (fs.File, error) {
 | 
				
			|||||||
	// always overwrite the ref to the gitea-pages branch
 | 
						// always overwrite the ref to the gitea-pages branch
 | 
				
			||||||
	if !hasConfig && (repo == c.giteapages || ref == c.giteapages) {
 | 
						if !hasConfig && (repo == c.giteapages || ref == c.giteapages) {
 | 
				
			||||||
		ref = c.giteapages
 | 
							ref = c.giteapages
 | 
				
			||||||
	} else if !validRefs(ref) {
 | 
						} else if !validRefs(ref, allowall) {
 | 
				
			||||||
		return nil, fs.ErrNotExist
 | 
							return nil, fs.ErrNotExist
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -174,7 +182,9 @@ func handleMD(res []byte) ([]byte, error) {
 | 
				
			|||||||
		return nil, err
 | 
							return nil, err
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	res = append([]byte("<!DOCTYPE html>\n<html>\n<body>\n<h1>"), []byte(meta["title"].(string))...)
 | 
						title, _ := meta["title"].(string)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						res = append([]byte("<!DOCTYPE html>\n<html>\n<body>\n<h1>"), []byte(title)...)
 | 
				
			||||||
	res = append(res, []byte("</h1>")...)
 | 
						res = append(res, []byte("</h1>")...)
 | 
				
			||||||
	res = append(res, resmd...)
 | 
						res = append(res, resmd...)
 | 
				
			||||||
	res = append(res, []byte("</body></html>")...)
 | 
						res = append(res, []byte("</body></html>")...)
 | 
				
			||||||
@ -196,19 +206,25 @@ func (c *Client) hasRepoBranch(owner, repo, branch string) bool {
 | 
				
			|||||||
	return b.Name == branch
 | 
						return b.Name == branch
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
func (c *Client) allowsPages(owner, repo string) bool {
 | 
					func (c *Client) allowsPages(owner, repo string) (bool, bool) {
 | 
				
			||||||
	topics, err := c.repoTopics(owner, repo)
 | 
						topics, err := c.repoTopics(owner, repo)
 | 
				
			||||||
	if err != nil {
 | 
						if err != nil {
 | 
				
			||||||
		return false
 | 
							return false, false
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						for _, topic := range topics {
 | 
				
			||||||
 | 
							if topic == c.giteapagesAllowAll {
 | 
				
			||||||
 | 
								return true, true
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	for _, topic := range topics {
 | 
						for _, topic := range topics {
 | 
				
			||||||
		if topic == c.giteapages {
 | 
							if topic == c.giteapages {
 | 
				
			||||||
			return true
 | 
								return true, false
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	return false
 | 
						return false, false
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
func (c *Client) readConfig(owner, repo string) error {
 | 
					func (c *Client) readConfig(owner, repo string) error {
 | 
				
			||||||
@ -236,7 +252,11 @@ func splitName(name string) (string, string, string) {
 | 
				
			|||||||
	}
 | 
						}
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
func validRefs(ref string) bool {
 | 
					func validRefs(ref string, allowall bool) bool {
 | 
				
			||||||
 | 
						if allowall {
 | 
				
			||||||
 | 
							return true
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	validrefs := viper.GetStringSlice("allowedrefs")
 | 
						validrefs := viper.GetStringSlice("allowedrefs")
 | 
				
			||||||
	for _, r := range validrefs {
 | 
						for _, r := range validrefs {
 | 
				
			||||||
		if r == ref {
 | 
							if r == ref {
 | 
				
			||||||
 | 
				
			|||||||
		Loading…
	
		Reference in New Issue
	
	Block a user