mirror of
				https://codeberg.org/forgejo/forgejo.git
				synced 2025-10-20 19:52:04 +00:00 
			
		
		
		
	This PR detects Interlisp files (files that include "(DEFINE-FILE-INFO" somewhere near the start, and do not have an .LCOM extension) as text files and displays them as such in the web UI. To check for extensions, I had to extend the `typesniffer.DetectContentType` function to accept an extra filename parameter—which could be useful for future filetype detection features. It is possible that a few of the places I modified pass a full file path instead of just passing a file name. Implements #8184 ## Checklist ### Tests - I added test coverage for Go changes... - [x] in their respective `*_test.go` for unit tests. - [ ] in the `tests/integration` directory if it involves interactions with a live Forgejo server. - I added test coverage for JavaScript changes... - NA - [ ] in `web_src/js/*.test.js` if it can be unit tested. - [ ] in `tests/e2e/*.test.e2e.js` if it requires interactions with a live Forgejo server (see also the [developer guide for JavaScript testing](https://codeberg.org/forgejo/forgejo/src/branch/forgejo/tests/e2e/README.md#end-to-end-tests)). ### Documentation - [ ] I created a pull request [to the documentation](https://codeberg.org/forgejo/docs) to explain to Forgejo users how to use this change. - [x] I did not document these changes and I do not expect someone else to do it. ### Release notes - [ ] I do not want this change to show in the release notes. - [x] I want the title to show in the release notes with a link to this pull request. - [ ] I want the content of the `release-notes/<pull request number>.md` to be be used for the release notes instead of the title. <!--start release-notes-assistant--> ## Release notes <!--URL:https://codeberg.org/forgejo/forgejo--> - Features - [PR](https://codeberg.org/forgejo/forgejo/pulls/8377): <!--number 8377 --><!--line 0 --><!--description ZGV0ZWN0IEludGVybGlzcCBzb3VyY2VzIGFzIHRleHQ=-->detect Interlisp sources as text<!--description--> <!--end release-notes-assistant--> Reviewed-on: https://codeberg.org/forgejo/forgejo/pulls/8377 Reviewed-by: Gusted <gusted@noreply.codeberg.org> Co-authored-by: Bojidar Marinov <bojidar.marinov.bg@gmail.com> Co-committed-by: Bojidar Marinov <bojidar.marinov.bg@gmail.com>
		
			
				
	
	
		
			76 lines
		
	
	
	
		
			2.2 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			76 lines
		
	
	
	
		
			2.2 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| // Copyright 2023 The Gitea Authors. All rights reserved.
 | |
| // SPDX-License-Identifier: MIT
 | |
| 
 | |
| package setting
 | |
| 
 | |
| import (
 | |
| 	"errors"
 | |
| 	"fmt"
 | |
| 	"io"
 | |
| 
 | |
| 	"forgejo.org/modules/log"
 | |
| 	"forgejo.org/modules/setting"
 | |
| 	"forgejo.org/modules/typesniffer"
 | |
| 	"forgejo.org/modules/web"
 | |
| 	"forgejo.org/services/context"
 | |
| 	"forgejo.org/services/forms"
 | |
| 	repo_service "forgejo.org/services/repository"
 | |
| )
 | |
| 
 | |
| // UpdateAvatarSetting update repo's avatar
 | |
| func UpdateAvatarSetting(ctx *context.Context, form forms.AvatarForm) error {
 | |
| 	ctxRepo := ctx.Repo.Repository
 | |
| 
 | |
| 	if form.Avatar == nil {
 | |
| 		// No avatar is uploaded and we not removing it here.
 | |
| 		// No random avatar generated here.
 | |
| 		// Just exit, no action.
 | |
| 		if ctxRepo.CustomAvatarRelativePath() == "" {
 | |
| 			log.Trace("No avatar was uploaded for repo: %d. Default icon will appear instead.", ctxRepo.ID)
 | |
| 		}
 | |
| 		return nil
 | |
| 	}
 | |
| 
 | |
| 	r, err := form.Avatar.Open()
 | |
| 	if err != nil {
 | |
| 		return fmt.Errorf("Avatar.Open: %w", err)
 | |
| 	}
 | |
| 	defer r.Close()
 | |
| 
 | |
| 	if form.Avatar.Size > setting.Avatar.MaxFileSize {
 | |
| 		return errors.New(ctx.Locale.TrString("settings.uploaded_avatar_is_too_big", form.Avatar.Size/1024, setting.Avatar.MaxFileSize/1024))
 | |
| 	}
 | |
| 
 | |
| 	data, err := io.ReadAll(r)
 | |
| 	if err != nil {
 | |
| 		return fmt.Errorf("io.ReadAll: %w", err)
 | |
| 	}
 | |
| 	st := typesniffer.DetectContentType(data, "")
 | |
| 	if !st.IsImage() || st.IsSvgImage() {
 | |
| 		return errors.New(ctx.Locale.TrString("settings.uploaded_avatar_not_a_image"))
 | |
| 	}
 | |
| 	if err = repo_service.UploadAvatar(ctx, ctxRepo, data); err != nil {
 | |
| 		return fmt.Errorf("UploadAvatar: %w", err)
 | |
| 	}
 | |
| 	return nil
 | |
| }
 | |
| 
 | |
| // SettingsAvatar save new POSTed repository avatar
 | |
| func SettingsAvatar(ctx *context.Context) {
 | |
| 	form := web.GetForm(ctx).(*forms.AvatarForm)
 | |
| 	form.Source = forms.AvatarLocal
 | |
| 	if err := UpdateAvatarSetting(ctx, *form); err != nil {
 | |
| 		ctx.Flash.Error(err.Error())
 | |
| 	} else {
 | |
| 		ctx.Flash.Success(ctx.Tr("repo.settings.update_avatar_success"))
 | |
| 	}
 | |
| 	ctx.Redirect(ctx.Repo.RepoLink + "/settings")
 | |
| }
 | |
| 
 | |
| // SettingsDeleteAvatar delete repository avatar
 | |
| func SettingsDeleteAvatar(ctx *context.Context) {
 | |
| 	if err := repo_service.DeleteAvatar(ctx, ctx.Repo.Repository); err != nil {
 | |
| 		ctx.Flash.Error(fmt.Sprintf("DeleteAvatar: %v", err))
 | |
| 	}
 | |
| 	ctx.JSONRedirect(ctx.Repo.RepoLink + "/settings")
 | |
| }
 |