-
-
Notifications
You must be signed in to change notification settings - Fork 5.6k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Support asciicast files as new markup (#22448)
Support [asciicast files](https://github.com/asciinema/asciinema/blob/develop/doc/asciicast-v2.md) as a new markup via [asciinema-player](https://github.com/asciinema/asciinema-player). For more on asciinema, see the [introduction](https://asciinema.org/). So users can use asciinema recorder to generate an asciicast file (or you can download a sample file from https://asciinema.org/a/335480.cast?dl=1), then upload it to Gitea and play it on Gitea. Snapshots: <details> ## Upload asciicast files <img width="1134" alt="image" src="https://user-images.githubusercontent.com/9418365/212461061-cc2c7181-0e14-4534-af55-1ec60a639fd1.png"> ## Open an asciicast file <img width="1137" alt="image" src="https://user-images.githubusercontent.com/9418365/212461090-a3b5141f-4894-430d-a2b4-ea257801a0ed.png"> ## Play it <img width="1144" alt="image" src="https://user-images.githubusercontent.com/9418365/212461157-4e82db69-0e41-471d-928f-ac1fe0737105.png"> ## Copy contents from the "video" <img width="1145" alt="image" src="https://user-images.githubusercontent.com/9418365/212461286-211612bc-15d6-427a-89a9-6abff5c6a0a5.png"> ## View the source <img width="1140" alt="image" src="https://user-images.githubusercontent.com/9418365/212461187-05473b2d-ba3d-4072-84a6-4aa1e7d82182.png"> </details> Known issue: Don't support the [v1 version asciicast files](https://github.com/asciinema/asciinema/blob/develop/doc/asciicast-v1.md), it's a poorly designed version, it does not specify the file extension and uses `*.json` usually, so it's impossible to recognize the files. Co-authored-by: silverwind <me@silverwind.io> Co-authored-by: Lunny Xiao <xiaolunwen@gmail.com>
- Loading branch information
1 parent
de484e8
commit d9f748a
Showing
9 changed files
with
173 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,64 @@ | ||
// Copyright 2023 The Gitea Authors. All rights reserved. | ||
// SPDX-License-Identifier: MIT | ||
|
||
package asciicast | ||
|
||
import ( | ||
"fmt" | ||
"io" | ||
"net/url" | ||
"regexp" | ||
|
||
"code.gitea.io/gitea/modules/markup" | ||
"code.gitea.io/gitea/modules/setting" | ||
) | ||
|
||
func init() { | ||
markup.RegisterRenderer(Renderer{}) | ||
} | ||
|
||
// Renderer implements markup.Renderer for asciicast files. | ||
// See https://github.com/asciinema/asciinema/blob/develop/doc/asciicast-v2.md | ||
type Renderer struct{} | ||
|
||
// Name implements markup.Renderer | ||
func (Renderer) Name() string { | ||
return "asciicast" | ||
} | ||
|
||
// Extensions implements markup.Renderer | ||
func (Renderer) Extensions() []string { | ||
return []string{".cast"} | ||
} | ||
|
||
const ( | ||
playerClassName = "asciinema-player-container" | ||
playerSrcAttr = "data-asciinema-player-src" | ||
) | ||
|
||
// SanitizerRules implements markup.Renderer | ||
func (Renderer) SanitizerRules() []setting.MarkupSanitizerRule { | ||
return []setting.MarkupSanitizerRule{ | ||
{Element: "div", AllowAttr: "class", Regexp: regexp.MustCompile(playerClassName)}, | ||
{Element: "div", AllowAttr: playerSrcAttr}, | ||
} | ||
} | ||
|
||
// Render implements markup.Renderer | ||
func (Renderer) Render(ctx *markup.RenderContext, _ io.Reader, output io.Writer) error { | ||
rawURL := fmt.Sprintf("%s/%s/%s/raw/%s/%s", | ||
setting.AppSubURL, | ||
url.PathEscape(ctx.Metas["user"]), | ||
url.PathEscape(ctx.Metas["repo"]), | ||
ctx.Metas["BranchNameSubURL"], | ||
url.PathEscape(ctx.RelativePath), | ||
) | ||
|
||
_, err := io.WriteString(output, fmt.Sprintf( | ||
`<div class="%s" %s="%s"></div>`, | ||
playerClassName, | ||
playerSrcAttr, | ||
rawURL, | ||
)) | ||
return err | ||
} |
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,14 @@ | ||
export async function renderAsciinemaPlayer() { | ||
const els = document.querySelectorAll('.asciinema-player-container'); | ||
if (!els.length) return; | ||
|
||
const player = await import(/* webpackChunkName: "asciinema-player" */'asciinema-player'); | ||
|
||
for (const el of els) { | ||
player.create(el.getAttribute('data-asciinema-player-src'), el, { | ||
// poster (a preview frame) to display until the playback is started. | ||
// Set it to 1 hour (also means the end if the video is shorter) to make the preview frame show more. | ||
poster: 'npt:1:0:0', | ||
}); | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -470,6 +470,10 @@ | |
pre { | ||
overflow: auto; | ||
} | ||
|
||
.asciicast { | ||
padding: 5px !important; | ||
} | ||
} | ||
|
||
.sidebar { | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,10 @@ | ||
@import "../asciinema-player/dist/bundle/asciinema-player.css"; | ||
|
||
.asciinema-player-container { | ||
width: 100%; | ||
height: auto; | ||
} | ||
|
||
.asciinema-terminal { | ||
overflow: hidden !important; | ||
} |