Moodle开发笔记3-Filter开发

2024-04-19 22:48
文章标签 开发 笔记 filter moodle

本文主要是介绍Moodle开发笔记3-Filter开发,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

 

Moodle filters 是对修改来自 database content 进行过滤修改后再输出显示。

 

一个例子是 moodle 自带的 multimedia filter ,它能够 detect references to video and audio files ,然后 replace them with a "mini-player" embedded in the content

 

Filter 的工作原理

Moodle 里所有要输出到 screen text 都要经过 format_text function 的处理,该函数会使其 safe to be displayed there are no security issues and that any HTML used contains only allowed tags

 

而且, text还会经过 filter_text function 的处理, 该函数会 apply all enabled filters to 传过来的 text 。该函数返回的是 the result of all of these filters

 

 

下面讲解如何开发一个简单的 filter ,该 filter 会对所有 ” Learning is Fun” 的字眼,都把它转化成带指向 http://2fun2learn.org link

 

1. create “learningisfunlink” folder ( 目录名是你的 filter name) in ”moodle/filter” folder

 

2. create “filter.php” under ”learningisfunlink” folder

filter.php 只需要添加一个函数 learningisfunlink_filter ”  ( 格式为 [filter_name]_filter ) ,该函数带有 2 个参数: course ID and 要过滤的 text 。下面的例子是最简单的 filter ,就是把 text 原样输出。

<?php

function learningisfunlink_filter($courseid, $text) {

return $text;

}

?>

 

3. (Optional) add language file language file详见 block开发)

如果不使用 language file,那么在 filter manage page里显示该 filter name就是learningisfunlink ,但如果我们的 lang/en_utf8/filter_learningisfunlink.php 里添加下列的 code

$string['filtername'] = "Main website link";

那么在 filter manage page里该 filter name "Main website link "

 

4. 修改步骤 2 filter.php learningisfunlink_filter函数 ,使得碰到 ” Learning is Fun” 的字眼就转成 link

 

会用到 /lib/filterlib.php file 里的 filterobject class and the filter_phrases function .

 

filterobject class 定义了一个 object 来包含所有 filter_phrases function 所要的 info

·         filter string

·         the tag to start the replacement with

·         the tag to end the replacement with

·         whether to match case (optional)

·         whether a full match is required (optional)

·         any replacement text for the match

 

filter_phrases($text, $filterobjects) 函数是根据参数 $filterobjects it is an array )来处理第一个参数的 text ,然后返回处理后的 string

 

修改后的 learningisfunlink_filter函数 代码为

function learningisfunlink_filter($courseid, $text) {

//create filterobjects obj

$searchphrase = "learning is fun";

$starttag = "<a href=/"http://2fun2learn.org/">";

$endtag = "</a>";

$filterobjects = array();

$filterobjects[] = new filterobject($searchphrase, $starttag, $endtag);

 

// change any occurrence of the phrase "learning is fun" to a hyperlinked phrase

return filter_phrases($text, $filterobjects);

}

 

注意: filter 要先在 ”Site Administration Block -> Modules -> Filters -> Manage filters” activate 才可使用。

 

 

5. add configuration settings 我们希望能够动态的设置要添加 link 的字串,而不是设死是 ” Learning is Fun” 。同时能够动态设置 link url 。因此我们就要使 filter 具有 configuration 的功能(这样在 filter manage page 里该 filter 就会 多一个 ”setting” link )。

 

1) 添加一个 filtersettings.php under ”learningisfunlink” folder 。当你创建了该文件后,该 filter manage page 里马上就会出现 ”setting” link

 

filtersettings.php会用到 $settings variable and admin_settingpage class

 

$settings 变量 是由 moodle帮我们创建的( /admin/settings/plugins.php里创建 ),该变量是一个数组类型,它包含 class admin_settingpage的对象元素

 

那么 我们的 filter configuration设置的东东,就会被 wrap into a admin_settingpage object,然后添加到变量 $settings

 

admin_setting_configtext 的构造方法为

admin_setting_configtext($name, $visiblename, $description, $defaultsetting,

                                                                        $paramtype=PARAM_RAW, $size=null)

第一个参数最为关键,它相当于 key ,必须在 $settings 里是唯一的。它的格式应该为 [module_type]_[module_name]_key 。例如该例中的 filter_learningisfunlink_phrase

 

因此修改后的 filtersettings.php 为:

<?php

    $settings->add(new admin_setting_configtext('filter_learningisfunlink_phrase',

                   'Phrase', 'Phrase to hyperlink ', 'learning is fun '));

 

    $settings->add(new admin_setting_configtext('filter_learningisfunlink_link',

                   'url', 'URL to link phrase to ', 'http://2fun.org'));

?>

 

对于上面的代码,当你进入该 filter configuration page 时,就会有 2 textbox ,它们的 name 分别为“ filter_learningisfunlink_phrase and filter_learningisfunlink_link ”,当你 submit 时,这 2 text box 的值就会自动付给“ filter_learningisfunlink_phrase and filter_learningisfunlink_link ”的 admin_setting_configtext 变量,并把这 2 个变量添加到 $CFG 变量里(见下面的代码就清楚) .

 

注意:使用 admin_setting_configtext ,对应的就会在 configuration page 里出现 text box 供你设置。如果你希望使用其他类型的设置,可以使用下列 class

·         admin_setting_configselect 用于 list box设置

·         admin_setting_configtextarea 用于 text area设置

等。

 

 

2) 上面的步骤的 configuration 设置好之后,设置的变量被存到 $CFG 里了。我们应该修改 filter.php 来使用它们

 

global $CFG;

if (!isset ($CFG->filter_learningisfunlink_phrase )) {

set_config ( 'filter_learningisfunlink_phrase',

get_string('phrasedefault', 'filter_learningisfunlink'));

}

if (!isset($CFG->filter_learningisfunlink_link)) {

set_config( 'filter_learningisfunlink_link',

get_string('linkdefault', 'filter_learningisfunlink'));

}

 

$searchphrase = $CFG->filter_learningisfunlink_phrase ;

$starttag = "<a href=/"{$CFG->filter_learningisfunlink_link}/">";

$endtag = "</a>";

 

$filterobjects = array();

$filterobjects[] = new filterobject($searchphrase, $starttag, $endtag);

 

return filter_phrases($text, $filterobjects);

 

注意:上面的代码会先 check $CFG 里是否存在我们想要的设置的 key ,如果不存在,就通过 set_config 函数往 $CFG 里添加该 key with default value

 

这篇关于Moodle开发笔记3-Filter开发的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/918652

相关文章

深度解析Spring Boot拦截器Interceptor与过滤器Filter的区别与实战指南

《深度解析SpringBoot拦截器Interceptor与过滤器Filter的区别与实战指南》本文深度解析SpringBoot中拦截器与过滤器的区别,涵盖执行顺序、依赖关系、异常处理等核心差异,并... 目录Spring Boot拦截器(Interceptor)与过滤器(Filter)深度解析:区别、实现

SpringBoot开发中十大常见陷阱深度解析与避坑指南

《SpringBoot开发中十大常见陷阱深度解析与避坑指南》在SpringBoot的开发过程中,即使是经验丰富的开发者也难免会遇到各种棘手的问题,本文将针对SpringBoot开发中十大常见的“坑... 目录引言一、配置总出错?是不是同时用了.properties和.yml?二、换个位置配置就失效?搞清楚加

Python中对FFmpeg封装开发库FFmpy详解

《Python中对FFmpeg封装开发库FFmpy详解》:本文主要介绍Python中对FFmpeg封装开发库FFmpy,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录一、FFmpy简介与安装1.1 FFmpy概述1.2 安装方法二、FFmpy核心类与方法2.1 FF

基于Python开发Windows屏幕控制工具

《基于Python开发Windows屏幕控制工具》在数字化办公时代,屏幕管理已成为提升工作效率和保护眼睛健康的重要环节,本文将分享一个基于Python和PySide6开发的Windows屏幕控制工具,... 目录概述功能亮点界面展示实现步骤详解1. 环境准备2. 亮度控制模块3. 息屏功能实现4. 息屏时间

Python实例题之pygame开发打飞机游戏实例代码

《Python实例题之pygame开发打飞机游戏实例代码》对于python的学习者,能够写出一个飞机大战的程序代码,是不是感觉到非常的开心,:本文主要介绍Python实例题之pygame开发打飞机... 目录题目pygame-aircraft-game使用 Pygame 开发的打飞机游戏脚本代码解释初始化部

使用Python开发一个现代化屏幕取色器

《使用Python开发一个现代化屏幕取色器》在UI设计、网页开发等场景中,颜色拾取是高频需求,:本文主要介绍如何使用Python开发一个现代化屏幕取色器,有需要的小伙伴可以参考一下... 目录一、项目概述二、核心功能解析2.1 实时颜色追踪2.2 智能颜色显示三、效果展示四、实现步骤详解4.1 环境配置4.

Python使用smtplib库开发一个邮件自动发送工具

《Python使用smtplib库开发一个邮件自动发送工具》在现代软件开发中,自动化邮件发送是一个非常实用的功能,无论是系统通知、营销邮件、还是日常工作报告,Python的smtplib库都能帮助我们... 目录代码实现与知识点解析1. 导入必要的库2. 配置邮件服务器参数3. 创建邮件发送类4. 实现邮件

基于Python开发一个有趣的工作时长计算器

《基于Python开发一个有趣的工作时长计算器》随着远程办公和弹性工作制的兴起,个人及团队对于工作时长的准确统计需求日益增长,本文将使用Python和PyQt5打造一个工作时长计算器,感兴趣的小伙伴可... 目录概述功能介绍界面展示php软件使用步骤说明代码详解1.窗口初始化与布局2.工作时长计算核心逻辑3

python web 开发之Flask中间件与请求处理钩子的最佳实践

《pythonweb开发之Flask中间件与请求处理钩子的最佳实践》Flask作为轻量级Web框架,提供了灵活的请求处理机制,中间件和请求钩子允许开发者在请求处理的不同阶段插入自定义逻辑,实现诸如... 目录Flask中间件与请求处理钩子完全指南1. 引言2. 请求处理生命周期概述3. 请求钩子详解3.1

如何基于Python开发一个微信自动化工具

《如何基于Python开发一个微信自动化工具》在当今数字化办公场景中,自动化工具已成为提升工作效率的利器,本文将深入剖析一个基于Python的微信自动化工具开发全过程,有需要的小伙伴可以了解下... 目录概述功能全景1. 核心功能模块2. 特色功能效果展示1. 主界面概览2. 定时任务配置3. 操作日志演示