默认情况下,Studio的注册用户都可以创建课程,这种默认行为似乎并不是通常的使用场景,平台拥有者更倾向于做个审核,才允许用户发布课程
读wiki啊!!
对于折腾edX的新手而言,我觉得首要的工作就两点:
1. 让平台跑起来
2. 通读wiki(configuration wiki和edx-platform wiki)
如果你通读了wiki,起步阶段的多数的问题其实都不成问题。
据说现在流行送鸡汤必须赠勺,我就写下可操作的解决方案好了。
跟官方的教程基本一样,官方wiki里有几处不够清晰,我加了自己的理解,没有直接翻译,没有完全按照它们的做法,在本地测试可用,你想按照wiki里的做法,可以自行阅读文后英文wiki。或者跟我往下做也行,有问题给我发邮件 : )
首先得区分django站点级别的is_staff和课程级别的course staff的区别,前者拥有站点内容编辑权限(好比登录admin),而后者只是作为课程团队成员,拥有的编辑课程内容的权限,是application级别的 (不理解也没啥关系)
经过以下设置,课程团队成员(course staff)依然可以编辑课程内容,而创建课程则需要被审核为is_staff的用户才可.这在逻辑上也好理解,只要平台认可的内部成员才有创建课程的权限
至于如何设置用户的is_staff为yes,则需要使用管理员账户登录到admin,更改auth表就行(/admin/auth/user)
cd /edx/app/edxapp/edx-platform
更改 edx-platform/cms/envs/common.py
在FEATURES里添加'DISABLE_COURSE_CREATION': True
./manage.py lms set_staff emailaddress
以上是命令行版本,我更喜欢直接去admin里标记:使用超级账号登录到admin,然后进入auth用户表(/admin/auth/user),选择相应用户,勾选对应选项就行
如否你做了以上设置,那么一般注册用户默认就没法创建课程,而他又确实想创建,他怎么请求你把他标记为is_staff?cd /edx/app/edxapp/edx-platform
更改 edx-platform/cms/envs/common.py
在FEATURES里添加'STUDIO_REQUEST_EMAIL':YOUR_EMAIL_ADDRESS
,这个邮箱将收到用户的请求
sudo /edx/bin/supervisorctl -c /edx/etc/supervisord.conf restart edxapp:
ps : birch版本有些不同,改为:sudo /edx/bin/supervisorctl restart edxapp:
方法一感觉有些hack,以下这个方案来得似乎更优雅些
已被标记为is_staff的用户,不受以下方法影响,永远可以创建课程
cd /edx/app/edxapp/edx-platform
更改 edx-platform/cms/envs/common.py
在FEATURES里添加'ENABLE_CREATOR_GROUP': True
需要注意的是,如果采用这个方案,方案一中提到的DISABLE_COURSE_CREATION
不应当为True
,因为DISABLE_COURSE_CREATION
的优先级更高
cd /edx/app/edxapp/edx-platform # 更新数据库 sudo -u www-data /edx/bin/python.edxapp ./manage.py cms syncdb --migrate --settings aws --migrate –noinput # 重启edxapp, birch版本有些不同,改为:sudo /edx/bin/supervisorctl restart edxapp: sudo /edx/bin/supervisorctl -c /edx/etc/supervisord.conf restart edxapp:
如果将ENABLE_CREATOR_GROUP设置为true,一个新的Studio用户的工作流是这样的:
对应的管理地址是/admin/course_creators/coursecreator/
和方法一相同
如果你希望给既有课程创建者授权,可通过这条指令./manage.py cms populate_creators
(嗯,你首先当然得在edx-platform目录下)