An open API service indexing awesome lists of open source software.

https://github.com/yoannchb-pro/moodlegpt

This extension allows you to hide CHAT-GPT in a Moodle quiz.
https://github.com/yoannchb-pro/moodlegpt

chatgpt chatgpt-api chatgpt-app edge-extension extension-chrome gpt-3 gpt-4 javascript moodle moodle-plugin quiz-solutions solver typescript

Last synced: 7 months ago
JSON representation

This extension allows you to hide CHAT-GPT in a Moodle quiz.

Awesome Lists containing this project

README

          

Mortarboard icons created by itim2101 - Flaticon

# MoodleGPT 1.1.3

This extension allows you to hide CHAT-GPT in a Moodle quiz. You just need to click on the question you want to solve, and CHAT-GPT will automatically provide the answer. However, one needs to be careful because as we know, CHAT-GPT can make errors especially in calculations.

## Chrome Webstore

Find the extension on the Chrome Webstore right [here](https://chrome.google.com/webstore/detail/moodlegpt/fgiepdkoifhpcgdhbiikpgdapjdoemko)

## Summary

- [MoodleGPT 1.1.3](#moodlegpt-113)
- [Chrome Webstore](#chrome-webstore)
- [Summary](#summary)
- [Disclaimer !](#disclaimer-)
- [Donate](#donate)
- [Update](#update)
- [Set up](#set-up)
- [Settings](#settings)
- [Advanced Settings](#advanced-settings)
- [Mode](#mode)
- [Options](#options)
- [Internal other features](#internal-other-features)
- [Support table](#support-table)
- [Supported questions type](#supported-questions-type)
- [Select](#select)
- [Put in order question](#put-in-order-question)
- [Resolve equation](#resolve-equation)
- [One response (radio button)](#one-response-radio-button)
- [Multiples responses (checkbox)](#multiples-responses-checkbox)
- [True or false](#true-or-false)
- [Number](#number)
- [Text](#text)
- [Atto](#atto)
- [What about if the question can't be autocompleted ?](#what-about-if-the-question-cant-be-autocompleted-)
- [Test](#test)
- [Beta version with advanced features](#beta-version-with-advanced-features)

## Disclaimer !

I hereby declare that I am not responsible for any misuse or illegal activities carried out using my program. The code is provided for educational and research purposes only, and any use of it outside of these purposes is at the user's own risk.

## Donate

Will be a pleasure if you want to support this project :). I'm alone working on this project and I'm still a student.


Mortarboard icons created by itim2101 - Flaticon

## Update

See the [changelog](./CHANGELOG.md) to see every updates !

## Set up

> NOTE: This extension only works on Chromium-based browsers like Edge, Chrome, etc.


Popup

Go to "Manage my extensions" on your browser, then click on "Load unpacked extension" and select the "extension" folder. Afterwards, click on the extension icon and enter the ApiKey obtained from [openai api](https://platform.openai.com/api-keys). Finally, select a [gpt model](https://platform.openai.com/docs/models) (ensure it work with completion api).

## Settings

- API KEY\*: Your openai [API KEY](https://platform.openai.com/api-keys)
- GPT MODEL\*: The [gpt model](https://platform.openai.com/docs/models) (you can click on the play button to ensure the model work with the extension)

## Advanced Settings

- CODE: A code you will need to type on your keyboard to inject/remove the extension code from the moodle page. It allow you to be more discret and control the injection so it's recommended.
- BASE URL: The API endpoint if you need to use your own llm.
- MAX TOKENS: The max tokens length you want the api to respond with.

## Mode


Popup

- Autocomplete: The extension will complete the question for you by selecting the correct(s) answer(s).
- Clipboard: The response is copied into the clipboard.
- Question to answer: The question is converted to the answer and you can click on it to show back the question (or show back the answer).

Question to Answer

## Options


Popup

- Api key\*: the [openai api key](https://platform.openai.com/api-keys) from your account (Note you have to put credits by entering a credit card onto your account).
- GPT Model\*: the [gpt model](https://platform.openai.com/docs/models) you want to use.
- Code: a code to be more discret for injecting/removing the extension from the page. Simply type your code you entered into the configuration on the keyboard when you are on your moodle quiz and the extension will be inject. If you want to remove the injection just simply type back the code on your keyboard.
- Cursor indication: show a pointer cursor and a hourglass to know when the request is finished.
- Title indication: show some informations into the title to know for example if the code have been injected.

![Injected](./assets/title-injected.png)
- Console logs: show logs into the console for the question, chatgpt answer and which response has been chosen.

Logs
- Request timeout: if the request is too long it will be abort after 20 seconds.
- Typing effect: create a typing effect for text. Type any text and it will be replaced by the correct one. If you want to stop it press Backspace key.

![Typing](./assets/typing.gif)
- Mouseover effect: you will need to hover (or click for select) the question response to complete it automaticaly.

![Mouseover](./assets/mouseover.gif)

![Mouseover2](./assets/mouseover2.gif)
- Infinite try: click as much as you want on the question (don't forget to reset the question).
- Save history: allows you to create a conversation with ChatGPT by saving the previous question with its answer. However, note that it can consume a significant number of tokens.
- Include images (only work with gpt-4): allows you to include the images from the question to be send to the chatgpt api. The quality is reduced to 75% to use less tokens. However, note that it can consume a significant number of tokens.

![Images](./assets/images.gif)

## Internal other features

### Support table

Table are formated from the question to make it more readable for CHAT-GPT. Example of formatted table output:

```
id       | name  | birthDate  | cars
------------------------------------
Person 1 | Yvick | 15/08/1999 | yes 
Person 2 | Yann  | 19/01/2000 | no
```

![Table](./assets/table.gif)

## Supported questions type

### Select

![Select](./assets/select.gif)

### Put in order question

![Order](./assets/order.gif)

### Resolve equation

![Equations](./assets/equations.gif)

### One response (radio button)

![Radio](./assets/radio.gif)

### Multiples responses (checkbox)

![Checkbox](./assets/checkbox.gif)

### True or false

![True-false](./assets/true-false.gif)

### Number

![Number](./assets/number.gif)

### Text

![Text](./assets/text.gif)

### Atto

![Atto](./assets/atto.gif)

## What about if the question can't be autocompleted ?

To know if the answer has been copied to the clipboard, you can look at the title of the page which will become "Copied to clipboard" for 3 seconds if `Title indication` is on.

![Clipboard](./assets/clipboard.gif)

## Test

- Solution 1: Go on this [moodle demo page](https://moodle.org/demo).
- Solution 2: Run the `index.html` file located in the `test/fake-moodle` folder.

## Beta version with advanced features

If you're interested in accessing advanced features ahead of their official release, please consider downloading the extension from the [dev branch](https://github.com/yoannchb-pro/MoodleGPT/tree/dev). However, please be aware that this branch is under development and may contain bugs. If you encounter any issues, don't hesitate to contact me or create an issue on GitHub. Your feedback is invaluable in helping us improve the extension.