Skip to content

Commit

Permalink
Swap out turnitin plugins
Browse files Browse the repository at this point in the history
  • Loading branch information
rrusso committed Nov 29, 2023
1 parent 73c753a commit dd0bb89
Show file tree
Hide file tree
Showing 420 changed files with 75,575 additions and 19,449 deletions.
1 change: 1 addition & 0 deletions plagiarism/turnitin/.gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
.idea/*
45 changes: 45 additions & 0 deletions plagiarism/turnitin/.travis.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,45 @@
language: php

sudo: false

cache:
directories:
- $HOME/.composer/cache

php:
- 7.1
- 7.2

services:
- mysql
- postgresql

env:
global:
- IGNORE_PATHS=sdk/,pix/,vendor/
- IGNORE_NAMES=jquery*,styles.css,autoload_static.php
matrix:
- DB=pgsql MOODLE_BRANCH=MOODLE_36_STABLE
- DB=mysqli MOODLE_BRANCH=MOODLE_36_STABLE
- DB=pgsql MOODLE_BRANCH=MOODLE_37_STABLE
- DB=mysqli MOODLE_BRANCH=MOODLE_37_STABLE
- DB=pgsql MOODLE_BRANCH=MOODLE_38_STABLE
- DB=mysqli MOODLE_BRANCH=MOODLE_38_STABLE

before_install:
- phpenv config-rm xdebug.ini
- cd ../..
- composer selfupdate
- composer create-project -n --no-dev --prefer-dist blackboard-open-source/moodle-plugin-ci ci ^1
- export PATH="$(cd ci/bin; pwd):$(cd ci/vendor/bin; pwd):$PATH"

install:
- moodle-plugin-ci install

script:
- moodle-plugin-ci phplint
- moodle-plugin-ci phpmd
- moodle-plugin-ci csslint
- moodle-plugin-ci shifter
- moodle-plugin-ci validate
- moodle-plugin-ci phpunit
1,240 changes: 1,240 additions & 0 deletions plagiarism/turnitin/CHANGELOG.md

Large diffs are not rendered by default.

10 changes: 10 additions & 0 deletions plagiarism/turnitin/CONTRIBUTIONS.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
PLagiarism Plugin Contributions
------------------------------

We welcome contributions to all elements of the plugin. Since launch we've had a number of users provide us with fixes and enhancements through either pull request or commits linked to from the issues page. If you are interested in contributing enhancements, or would like to solve an issue raised by another user, please feel free to make a pull request against the develop branch.

Some users also contribute code that while not appropriate for every user may help them solve issues where their workflow is different from that of Turnitin. We'll link to them from this page if appropriate. Please note that we have not tested this code so we don't endorse it, we only provide a link to it here as other users feel someone else may find it useful.

------------------------------

tonyjbutler provided via [ISSUE 137](https://github.com/jmcgettrick/MoodleDirectV2/issues/137) - This will reduce the maximum file size of submissions to a Turnitin enabled Moodle assignment.
34 changes: 34 additions & 0 deletions plagiarism/turnitin/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,34 @@
Turnitin Plagiarism plugin for Moodle
=====================================

Please be aware that the **Develop** branch should not be considered production ready, although it contains the latest fixes and features it may contain bugs. It should be avoided in favour of the **Master** branch which is the latest available branch that has been through the QA process. Please make any pull requests you would like to make to the develop branch.

For running behat tests in Moodle 3.9 and above, please use the behat_39+ branch. There are some deprecated form settings methods in Moodle that throw warnings during behat test runs causing failures, unfortunately this is the only way around this issue as we don't want have different plugin branches per Moodle version.

To see what has changed in recent versions of the plagiarism plugin, see the [CHANGELOG](https://github.com/turnitin/moodle-plagiarism_turnitin/blob/master/CHANGELOG.md).

If you would like to contribute to the plugin please see our [CONTRIBUTIONS](https://github.com/turnitin/moodle-plagiarism_turnitin/blob/master/CONTRIBUTIONS.md) page.

If you are having issues, please consult our [TROUBLE SHOOTING](https://github.com/turnitin/moodle-plagiarism_turnitin/blob/master/TROUBLESHOOTING.md) page.

Installation
------------

Before installing this plugin firstly make sure you are logged in as an Administrator and that you are using Moodle 3.5 or higher.

The Plagiarism Plugin can be used within the following Moodle modules:

- Assignments
- Forums
- Quiz *
- Workshops

\* This is currently only essay type answers and is also reliant on Moodle merging [this code patch](https://github.com/moodle/moodle/commit/7a8e3ec4b13408d18734ab46bdb03b2da55f317d) into their core offering. For more information see: [MDL-32226](https://tracker.moodle.org/browse/MDL-32226).

To install, you need to copy all the files into the plagiarism/turnitin directory in your Moodle installation. You should then go to `"Site Administration" > "Notifications"` where you should follow the on screen instructions.

Plagiarism plugins also need to be enabled before this plugin can be used. You can do this by going to `"Site Administration" > "Advanced Features"` and ticking the "Enable plagiarism plugins" box before saving.

You can set default values and whether the plugin is enabled within Moodle modules by going to `"Site Administration" > "Plugins" > "Plagiarism prevention" > "Turnitin plagiarism plugin"`.

To create/update assignments, process submissions and update grades your moodle environment will need to have cron job running regularly. For information on how to do this please consult https://docs.moodle.org/37/en/Cron.
70 changes: 70 additions & 0 deletions plagiarism/turnitin/TROUBLESHOOTING.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,70 @@
#Turnitin Plagiarism Plugin Troubleshooting

1) You may need to ensure that within your designated moodledata directory; the plagiarism_turnitin subdirectory and the subsequent logs subdirectory have the correct permissions to be able to create directories and files.

2) Pop-ups will need to be enabled on the browser being used if access to the Turnitin Document Viewer is required.

3) There have been very isolated reports of the settings not showing for the Plagiarism plugin despite it being enabled, this is due to it not showing in Moodle cache. The solution is for an administrator to purge all caches and it should then appear.

##Required PHP Extensions

In order for the module to work correctly you must enable the following PHP extensions:

**cURL**

>You must enable support for cURL in your php.ini file. To do this locate the following line in your php.ini file:
>;extension=php_curl.dll
>OR
>;extension=php_curl.so
>Remove the semi-colon at the start of the line to activate the php cURL extension. Once you have done this you will need to restart your web server service.
>More information on cURL and more detailed instructions for installing it can be found here: http://uk3.php.net/curl

**XMLWriter**

>This is normally enabled by default but if PHP was compiled with --disable-xmlreader set then you will need to recompile PHP without --disable-xmlreader set.

**MBstring**

>You may be able to enable this setting by uncommenting the extension listing in your php.ini file:
>;extension=php_mbstring.dll
>Remove the semi-colon at the start of the line to activate the MBstring extension. Once you have done this you will need to restart your web server service.
>If you can't find this line in your php.ini file then you may need to install the php-mbstring first. For further information see: http://php.net/manual/en/mbstring.installation.php
**fileinfo**

>This extension is enabled by default as of PHP 5.3.0. Windows users must include the bundled php_fileinfo.dll DLL file in php.ini to enable this extension.
>For further information see http://php.net/manual/en/fileinfo.installation.php.
##cURL Connectivity

If you encounter connectivity issues (error: Turnitin API Base URL incorrect or unavailable) this could be related to a CA certificate being unavailable to cURL.

If cURL has an out of date (or no) CA certificates, the interaction with Turnitin will fail due to cURL performing peer SSL certificate verification and not being able to verify the Turnitin SSL certificate.
Until cURL 7.18.0 some CA certificates were provided, but after 7.18.0 no cs certificates have been provided at all. Because of this, the Moodle server administrator would need to ensure that an up to date CA certificate bundle is used. To be clear, Moodle doesn't need an SSL certificate, however, it needs to have the certificate bundle in place so cURL can recognize the SSL certificates of Turnitin.

Information on how to install a certificate bundle is available via the URLs below. Note that the URLs are third party sites and not affiliated with Turnitin or iParadigms in any way:

Information for Linux environments: http://docs.moodle.org/26/en/SSL_certificate_for_moodle.org

Information for Windows environments: http://curl.haxx.se/docs/sslcerts.html

##WSDL

We have had reported issues with users not being able to parse the WSDL files that the API requires. The relevant error message starts “PHP Fatal error: SOAP-ERROR: Parsing WSDL: ….”

From version 2014012405 onwards we have bundled the WSDL files with the plugin download, however the issue does still occur for some users. This is due to a PHP bug with libxml_disable_entity_loader() being set to true and preventing external entities from being loaded. If this is set by a PHP script then PHP uses this value for all processes on the server. For further information see: https://bugs.php.net/bug.php?id=64938.

To fix this, you need to add the following line to your to your moodle config.php:

libxml_disable_entity_loader(false);

Thanks to Dan Marsden for the information and solution.
Loading

0 comments on commit dd0bb89

Please sign in to comment.