mirror of
https://github.com/xfgryujk/blivechat.git
synced 2025-04-03 16:10:35 +08:00
添加custom_public目录,用来对前端暴露一些文件;添加导入服务器预设CSS选项
This commit is contained in:
parent
5773673bdf
commit
66daa5b79d
@ -21,4 +21,8 @@ data/*
|
|||||||
!data/emoticons/
|
!data/emoticons/
|
||||||
data/emoticons/*
|
data/emoticons/*
|
||||||
!data/emoticons/.gitkeep
|
!data/emoticons/.gitkeep
|
||||||
|
!data/custom_public/
|
||||||
|
data/custom_public/*
|
||||||
|
!data/custom_public/README.txt
|
||||||
|
!data/custom_public/preset.css
|
||||||
log/*
|
log/*
|
||||||
|
4
.gitignore
vendored
4
.gitignore
vendored
@ -110,4 +110,8 @@ data/*
|
|||||||
!data/emoticons/
|
!data/emoticons/
|
||||||
data/emoticons/*
|
data/emoticons/*
|
||||||
!data/emoticons/.gitkeep
|
!data/emoticons/.gitkeep
|
||||||
|
!data/custom_public/
|
||||||
|
data/custom_public/*
|
||||||
|
!data/custom_public/README.txt
|
||||||
|
!data/custom_public/preset.css
|
||||||
log/*
|
log/*
|
||||||
|
@ -14,6 +14,7 @@ logger = logging.getLogger(__name__)
|
|||||||
|
|
||||||
EMOTICON_UPLOAD_PATH = os.path.join(config.DATA_PATH, 'emoticons')
|
EMOTICON_UPLOAD_PATH = os.path.join(config.DATA_PATH, 'emoticons')
|
||||||
EMOTICON_BASE_URL = '/emoticons'
|
EMOTICON_BASE_URL = '/emoticons'
|
||||||
|
CUSTOM_PUBLIC_PATH = os.path.join(config.DATA_PATH, 'custom_public')
|
||||||
|
|
||||||
|
|
||||||
class MainHandler(tornado.web.StaticFileHandler):
|
class MainHandler(tornado.web.StaticFileHandler):
|
||||||
@ -85,6 +86,11 @@ class UploadEmoticonHandler(api.base.ApiHandler):
|
|||||||
return f'{EMOTICON_BASE_URL}/{filename}'
|
return f'{EMOTICON_BASE_URL}/{filename}'
|
||||||
|
|
||||||
|
|
||||||
|
class NoCacheStaticFileHandler(tornado.web.StaticFileHandler):
|
||||||
|
def set_extra_headers(self, path):
|
||||||
|
self.set_header('Cache-Control', 'no-cache')
|
||||||
|
|
||||||
|
|
||||||
ROUTES = [
|
ROUTES = [
|
||||||
(r'/api/server_info', ServerInfoHandler),
|
(r'/api/server_info', ServerInfoHandler),
|
||||||
(r'/api/emoticon', UploadEmoticonHandler),
|
(r'/api/emoticon', UploadEmoticonHandler),
|
||||||
@ -92,5 +98,7 @@ ROUTES = [
|
|||||||
# 通配的放在最后
|
# 通配的放在最后
|
||||||
LAST_ROUTES = [
|
LAST_ROUTES = [
|
||||||
(rf'{EMOTICON_BASE_URL}/(.*)', tornado.web.StaticFileHandler, {'path': EMOTICON_UPLOAD_PATH}),
|
(rf'{EMOTICON_BASE_URL}/(.*)', tornado.web.StaticFileHandler, {'path': EMOTICON_UPLOAD_PATH}),
|
||||||
|
# 这个目录不保证文件内容不会变,还是不用缓存了
|
||||||
|
(r'/custom_public/(.*)', NoCacheStaticFileHandler, {'path': CUSTOM_PUBLIC_PATH}),
|
||||||
(r'/(.*)', MainHandler, {'path': config.WEB_ROOT}),
|
(r'/(.*)', MainHandler, {'path': config.WEB_ROOT}),
|
||||||
]
|
]
|
||||||
|
7
data/custom_public/README.txt
Normal file
7
data/custom_public/README.txt
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
这个目录用来暴露一些自定义文件给前端,例如图片、CSS、字体等
|
||||||
|
你可以在网页路径 /custom_public/README.txt 访问到这个文件
|
||||||
|
警告:不要在这个目录里存放密钥等敏感信息,因为可能会被远程访问
|
||||||
|
|
||||||
|
This directory is used to expose some custom files to the front end, such as images, CSS, fonts, etc.
|
||||||
|
You can access this file on the web path: /custom_public/README.txt
|
||||||
|
WARNING: DO NOT store sensitive information such as secrets in this directory, because it may be accessed by remote
|
8
data/custom_public/preset.css
Normal file
8
data/custom_public/preset.css
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
/*
|
||||||
|
这是服务器预设CSS文件
|
||||||
|
前端可以通过“导入服务器预设CSS”选项自动导入这个CSS,而不需要在OBS里面设置自定义CSS
|
||||||
|
|
||||||
|
This is the server preset CSS file
|
||||||
|
The front end can automatically import this CSS through the "Import the server preset CSS" option,
|
||||||
|
instead of setting the custom CSS in OBS
|
||||||
|
*/
|
@ -22,6 +22,7 @@ export const DEFAULT_CONFIG = {
|
|||||||
relayMessagesByServer: false,
|
relayMessagesByServer: false,
|
||||||
autoTranslate: false,
|
autoTranslate: false,
|
||||||
giftUsernamePronunciation: '',
|
giftUsernamePronunciation: '',
|
||||||
|
importPresetCss: false,
|
||||||
|
|
||||||
emoticons: [] // [{ keyword: '', url: '' }, ...]
|
emoticons: [] // [{ keyword: '', url: '' }, ...]
|
||||||
}
|
}
|
||||||
|
@ -48,6 +48,8 @@ export default {
|
|||||||
dontShow: 'None',
|
dontShow: 'None',
|
||||||
pinyin: 'Pinyin',
|
pinyin: 'Pinyin',
|
||||||
kana: 'Kana',
|
kana: 'Kana',
|
||||||
|
importPresetCss: 'Import the server preset CSS',
|
||||||
|
importPresetCssTip: 'Automatically import the server CSS file: data/custom_public/preset.css',
|
||||||
|
|
||||||
emoticon: 'Custom Emotes',
|
emoticon: 'Custom Emotes',
|
||||||
emoticonKeyword: 'Emote Code',
|
emoticonKeyword: 'Emote Code',
|
||||||
|
@ -48,6 +48,8 @@ export default {
|
|||||||
dontShow: '非表示',
|
dontShow: '非表示',
|
||||||
pinyin: 'ピンイン',
|
pinyin: 'ピンイン',
|
||||||
kana: '仮名',
|
kana: '仮名',
|
||||||
|
importPresetCss: 'サーバープリセットのCSSをインポートする',
|
||||||
|
importPresetCssTip: 'サーバーのCSSファイル「data/custom_public/preset.css」を自動的にインポートする',
|
||||||
|
|
||||||
emoticon: 'カスタムスタンプ',
|
emoticon: 'カスタムスタンプ',
|
||||||
emoticonKeyword: '置き換えるキーワード',
|
emoticonKeyword: '置き換えるキーワード',
|
||||||
|
@ -48,6 +48,8 @@ export default {
|
|||||||
dontShow: '不显示',
|
dontShow: '不显示',
|
||||||
pinyin: '拼音',
|
pinyin: '拼音',
|
||||||
kana: '日文假名',
|
kana: '日文假名',
|
||||||
|
importPresetCss: '导入服务器预设CSS',
|
||||||
|
importPresetCssTip: '自动导入服务器的CSS文件:data/custom_public/preset.css',
|
||||||
|
|
||||||
emoticon: '自定义表情',
|
emoticon: '自定义表情',
|
||||||
emoticonKeyword: '替换关键词',
|
emoticonKeyword: '替换关键词',
|
||||||
|
@ -170,6 +170,15 @@
|
|||||||
<el-radio label="kana">{{$t('home.kana')}}</el-radio>
|
<el-radio label="kana">{{$t('home.kana')}}</el-radio>
|
||||||
</el-radio-group>
|
</el-radio-group>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
|
<el-row>
|
||||||
|
<el-col :xs="24" :sm="8">
|
||||||
|
<el-tooltip :content="$t('home.importPresetCssTip')">
|
||||||
|
<el-form-item :label="$t('home.importPresetCss')">
|
||||||
|
<el-switch v-model="form.importPresetCss"></el-switch>
|
||||||
|
</el-form-item>
|
||||||
|
</el-tooltip>
|
||||||
|
</el-col>
|
||||||
|
</el-row>
|
||||||
</el-tab-pane>
|
</el-tab-pane>
|
||||||
|
|
||||||
<el-tab-pane :label="$t('home.emoticon')">
|
<el-tab-pane :label="$t('home.emoticon')">
|
||||||
|
@ -43,6 +43,7 @@ export default {
|
|||||||
pronunciationConverter: null,
|
pronunciationConverter: null,
|
||||||
|
|
||||||
customStyleElement, // 仅用于样式生成器中预览样式
|
customStyleElement, // 仅用于样式生成器中预览样式
|
||||||
|
presetCssLinkElement: null,
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
computed: {
|
computed: {
|
||||||
@ -92,6 +93,9 @@ export default {
|
|||||||
}
|
}
|
||||||
|
|
||||||
document.head.removeChild(this.customStyleElement)
|
document.head.removeChild(this.customStyleElement)
|
||||||
|
if (this.presetCssLinkElement) {
|
||||||
|
document.head.removeChild(this.presetCssLinkElement)
|
||||||
|
}
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
onVisibilityChange() {
|
onVisibilityChange() {
|
||||||
@ -110,6 +114,12 @@ export default {
|
|||||||
this.pronunciationConverter = new pronunciation.PronunciationConverter()
|
this.pronunciationConverter = new pronunciation.PronunciationConverter()
|
||||||
this.pronunciationConverter.loadDict(this.config.giftUsernamePronunciation)
|
this.pronunciationConverter.loadDict(this.config.giftUsernamePronunciation)
|
||||||
}
|
}
|
||||||
|
if (this.config.importPresetCss) {
|
||||||
|
this.presetCssLinkElement = document.createElement('link')
|
||||||
|
this.presetCssLinkElement.rel = 'stylesheet'
|
||||||
|
this.presetCssLinkElement.href = '/custom_public/preset.css'
|
||||||
|
document.head.appendChild(this.presetCssLinkElement)
|
||||||
|
}
|
||||||
|
|
||||||
try {
|
try {
|
||||||
// 其他初始化就不用等了,就算失败了也不会有很大影响
|
// 其他初始化就不用等了,就算失败了也不会有很大影响
|
||||||
@ -159,6 +169,8 @@ export default {
|
|||||||
|
|
||||||
cfg.relayMessagesByServer = toBool(cfg.relayMessagesByServer)
|
cfg.relayMessagesByServer = toBool(cfg.relayMessagesByServer)
|
||||||
cfg.autoTranslate = toBool(cfg.autoTranslate)
|
cfg.autoTranslate = toBool(cfg.autoTranslate)
|
||||||
|
cfg.importPresetCss = toBool(cfg.importPresetCss)
|
||||||
|
|
||||||
cfg.emoticons = this.toObjIfJson(cfg.emoticons)
|
cfg.emoticons = this.toObjIfJson(cfg.emoticons)
|
||||||
|
|
||||||
chatConfig.sanitizeConfig(cfg)
|
chatConfig.sanitizeConfig(cfg)
|
||||||
|
@ -10,7 +10,10 @@ module.exports = {
|
|||||||
},
|
},
|
||||||
'/emoticons': {
|
'/emoticons': {
|
||||||
target: API_BASE_URL
|
target: API_BASE_URL
|
||||||
}
|
},
|
||||||
|
'/custom_public': {
|
||||||
|
target: API_BASE_URL
|
||||||
|
},
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
chainWebpack: config => {
|
chainWebpack: config => {
|
||||||
|
Loading…
Reference in New Issue
Block a user