shoom013 commited on
Commit
203f582
·
verified ·
1 Parent(s): ec80169

Upload 76 files

Browse files
This view is limited to 50 files because it contains too many changes.   See raw diff
Files changed (50) hide show
  1. bot/.DS_Store +0 -0
  2. bot/.views.py.swp +0 -0
  3. bot/__init__.py +0 -0
  4. bot/__pycache__/__init__.cpython-311.pyc +0 -0
  5. bot/__pycache__/admin.cpython-311.pyc +0 -0
  6. bot/__pycache__/apps.cpython-311.pyc +0 -0
  7. bot/__pycache__/forms.cpython-311.pyc +0 -0
  8. bot/__pycache__/models.cpython-311.pyc +0 -0
  9. bot/__pycache__/uchat.cpython-311.pyc +0 -0
  10. bot/__pycache__/urls.cpython-311.pyc +0 -0
  11. bot/__pycache__/views.cpython-311.pyc +0 -0
  12. bot/admin.py +6 -0
  13. bot/apps.py +6 -0
  14. bot/chroma_data/71205607-97fb-4292-8492-28d8f0cc5fef/data_level0.bin +3 -0
  15. bot/chroma_data/71205607-97fb-4292-8492-28d8f0cc5fef/header.bin +3 -0
  16. bot/chroma_data/71205607-97fb-4292-8492-28d8f0cc5fef/length.bin +3 -0
  17. bot/chroma_data/71205607-97fb-4292-8492-28d8f0cc5fef/link_lists.bin +3 -0
  18. bot/chroma_data/chroma.sqlite3 +0 -0
  19. bot/forms.py +62 -0
  20. bot/migrations/0001_initial.py +21 -0
  21. bot/migrations/0002_query.py +21 -0
  22. bot/migrations/0003_rename_text_query_query_language_lid_query_reply_and_more.py +35 -0
  23. bot/migrations/0004_param_alter_language_lid_alter_language_name.py +48 -0
  24. bot/migrations/__init__.py +0 -0
  25. bot/migrations/__pycache__/0001_initial.cpython-311.pyc +0 -0
  26. bot/migrations/__pycache__/0002_query.cpython-311.pyc +0 -0
  27. bot/migrations/__pycache__/0003_rename_text_query_query_language_lid_query_reply_and_more.cpython-311.pyc +0 -0
  28. bot/migrations/__pycache__/0004_param_alter_language_lid_alter_language_name.cpython-311.pyc +0 -0
  29. bot/migrations/__pycache__/__init__.cpython-311.pyc +0 -0
  30. bot/models.py +64 -0
  31. bot/static/css/styles.css +5 -0
  32. bot/test.wsgi +7 -0
  33. bot/tests.py +38 -0
  34. bot/tests/__init__.py +1 -0
  35. bot/tests/__pycache__/__init__.cpython-311.pyc +0 -0
  36. bot/tests/test_views.py +38 -0
  37. bot/uchat-old.py +322 -0
  38. bot/uchat.py +162 -0
  39. bot/urls.py +31 -0
  40. bot/views.py +624 -0
  41. templates/.DS_Store +0 -0
  42. templates/base_generic.html +74 -0
  43. templates/bot/language_detail.html +16 -0
  44. templates/bot/language_list.html +16 -0
  45. templates/index.html +41 -0
  46. templates/index_editor.html +76 -0
  47. templates/index_import.html +29 -0
  48. templates/index_params.html +107 -0
  49. templates/registration/logged_out.html +7 -0
  50. templates/registration/login.html +38 -0
bot/.DS_Store ADDED
Binary file (6.15 kB). View file
 
bot/.views.py.swp ADDED
Binary file (53.2 kB). View file
 
bot/__init__.py ADDED
File without changes
bot/__pycache__/__init__.cpython-311.pyc ADDED
Binary file (150 Bytes). View file
 
bot/__pycache__/admin.cpython-311.pyc ADDED
Binary file (355 Bytes). View file
 
bot/__pycache__/apps.cpython-311.pyc ADDED
Binary file (515 Bytes). View file
 
bot/__pycache__/forms.cpython-311.pyc ADDED
Binary file (4.38 kB). View file
 
bot/__pycache__/models.cpython-311.pyc ADDED
Binary file (5.52 kB). View file
 
bot/__pycache__/uchat.cpython-311.pyc ADDED
Binary file (10.3 kB). View file
 
bot/__pycache__/urls.cpython-311.pyc ADDED
Binary file (1.23 kB). View file
 
bot/__pycache__/views.cpython-311.pyc ADDED
Binary file (34.5 kB). View file
 
bot/admin.py ADDED
@@ -0,0 +1,6 @@
 
 
 
 
 
 
 
1
+ from django.contrib import admin
2
+ from .models import Language
3
+
4
+ admin.site.register(Language)
5
+
6
+ # Register your models here.
bot/apps.py ADDED
@@ -0,0 +1,6 @@
 
 
 
 
 
 
 
1
+ from django.apps import AppConfig
2
+
3
+
4
+ class BotConfig(AppConfig):
5
+ default_auto_field = 'django.db.models.BigAutoField'
6
+ name = 'bot'
bot/chroma_data/71205607-97fb-4292-8492-28d8f0cc5fef/data_level0.bin ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ version https://git-lfs.github.com/spec/v1
2
+ oid sha256:6a0f748340f882ae5b8ef64a529d2782a281c1fa7bb7be42203e031a07c2a2dd
3
+ size 1676000
bot/chroma_data/71205607-97fb-4292-8492-28d8f0cc5fef/header.bin ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ version https://git-lfs.github.com/spec/v1
2
+ oid sha256:e87a1dc8bcae6f2c4bea6d5dd5005454d4dace8637dae29bff3c037ea771411e
3
+ size 100
bot/chroma_data/71205607-97fb-4292-8492-28d8f0cc5fef/length.bin ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ version https://git-lfs.github.com/spec/v1
2
+ oid sha256:9d5aebd05d5bf364ed999da7c13f7ef2101df1dc00f19fc87758d2d7cc067582
3
+ size 4000
bot/chroma_data/71205607-97fb-4292-8492-28d8f0cc5fef/link_lists.bin ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ version https://git-lfs.github.com/spec/v1
2
+ oid sha256:e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855
3
+ size 0
bot/chroma_data/chroma.sqlite3 ADDED
Binary file (147 kB). View file
 
bot/forms.py ADDED
@@ -0,0 +1,62 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ from django.core.exceptions import ValidationError
2
+ #from django.utils.translation import gettext_lazy as _
3
+
4
+ from django import forms
5
+
6
+ class RenewBotForm(forms.Form):
7
+ query = forms.CharField(
8
+ help_text="Unesite upit: ")
9
+ jezik = forms.CharField(
10
+ help_text="Odaberite jezik")
11
+ # def clean_query(self):
12
+ # data = self.cleaned_data['query']
13
+ # data = self.cleaned_data['jezik']
14
+ # return data
15
+
16
+ class EditorForm(forms.Form):
17
+ id = forms.CharField(help_text="id")
18
+ state = forms.CharField(help_text="Početno stanje")
19
+ next = forms.CharField(help_text="Završno stanje")
20
+ page = forms.IntegerField(help_text="Stranica")
21
+ used = forms.CharField(help_text="Upotrebljen (Bool)")
22
+ docu = forms.CharField(help_text="Dokument konteksta")
23
+ source = forms.CharField(help_text="URL dokumenta")
24
+ jezik = forms.CharField(help_text="Odaberite jezik")
25
+ # def clean_query(self):
26
+ # data = self.cleaned_data['source']
27
+ # return data
28
+
29
+ class EditorListForm(forms.Form):
30
+ f_id = forms.IntegerField(help_text="id filter")
31
+ f_jezik = forms.CharField(help_text="jezik filter")
32
+ f_state = forms.CharField(help_text="state filter")
33
+ f_next = forms.CharField(help_text="next filter")
34
+ f_page = forms.IntegerField(help_text="page filter")
35
+ f_docu = forms.CharField(help_text="document filter")
36
+
37
+ class ParamForm(forms.Form):
38
+ system = forms.CharField(help_text="Enter parameter value")
39
+ ctxpre = forms.CharField(help_text="Enter parameter value")
40
+ msg_content = forms.CharField(help_text="Enter parameter value")
41
+ min_len = forms.IntegerField(help_text="Enter parameter value")
42
+ CHUNK_SIZE = forms.IntegerField(help_text="Enter parameter value")
43
+ CHUNK_OVERLAP = forms.IntegerField(help_text="Enter parameter value")
44
+ max_results = forms.IntegerField(help_text="Enter parameter value")
45
+ EMBED_MODEL = forms.CharField(help_text="Enter parameter value")
46
+ model_id = forms.CharField(help_text="Enter parameter value")
47
+ max_results = forms.IntegerField(help_text="Enter parameter value")
48
+ max_conv = forms.IntegerField(help_text="Enter parameter value")
49
+ min_len = forms.IntegerField(help_text="Enter parameter value")
50
+ min_distance = forms.FloatField(help_text="Enter parameter value")
51
+ max_distance = forms.FloatField(help_text="Enter parameter value")
52
+ temperature = forms.FloatField(help_text="Enter parameter value")
53
+ max_tokens = forms.IntegerField(help_text="Enter parameter value")
54
+ top_p = forms.FloatField(help_text="Enter parameter value")
55
+ frequency_penalty = forms.FloatField(help_text="Enter parameter value")
56
+ presence_penalty = forms.FloatField(help_text="Enter parameter value")
57
+ DEBUG = forms.CharField(help_text="Enter parameter value (Bool)")
58
+ jezik = forms.CharField(help_text="Uneti jezik")
59
+
60
+ class ImportForm(forms.Form):
61
+ path = forms.CharField(help_text="Unesite putanju do PDF dokumenta")
62
+ jezik = forms.CharField(help_text="Unesite jezik")
bot/migrations/0001_initial.py ADDED
@@ -0,0 +1,21 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ # Generated by Django 5.0.3 on 2024-04-04 02:48
2
+
3
+ from django.db import migrations, models
4
+
5
+
6
+ class Migration(migrations.Migration):
7
+
8
+ initial = True
9
+
10
+ dependencies = [
11
+ ]
12
+
13
+ operations = [
14
+ migrations.CreateModel(
15
+ name='Language',
16
+ fields=[
17
+ ('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
18
+ ('name', models.CharField(help_text='Enter language (e.g. English, French, Japanese etc.)', max_length=200, unique=True)),
19
+ ],
20
+ ),
21
+ ]
bot/migrations/0002_query.py ADDED
@@ -0,0 +1,21 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ # Generated by Django 5.0.3 on 2024-04-06 04:37
2
+
3
+ from django.db import migrations, models
4
+
5
+
6
+ class Migration(migrations.Migration):
7
+
8
+ dependencies = [
9
+ ('bot', '0001_initial'),
10
+ ]
11
+
12
+ operations = [
13
+ migrations.CreateModel(
14
+ name='Query',
15
+ fields=[
16
+ ('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
17
+ ('text', models.TextField(help_text='Unesite upit', max_length=1000)),
18
+ ('jezik', models.CharField(help_text='Odaberite jezik!', max_length=16)),
19
+ ],
20
+ ),
21
+ ]
bot/migrations/0003_rename_text_query_query_language_lid_query_reply_and_more.py ADDED
@@ -0,0 +1,35 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ # Generated by Django 5.0.3 on 2024-04-10 18:33
2
+
3
+ from django.db import migrations, models
4
+
5
+
6
+ class Migration(migrations.Migration):
7
+
8
+ dependencies = [
9
+ ('bot', '0002_query'),
10
+ ]
11
+
12
+ operations = [
13
+ migrations.RenameField(
14
+ model_name='query',
15
+ old_name='text',
16
+ new_name='query',
17
+ ),
18
+ migrations.AddField(
19
+ model_name='language',
20
+ name='lid',
21
+ field=models.CharField(default='sr', help_text='Unesite kratak naziv jezika', max_length=2),
22
+ preserve_default=False,
23
+ ),
24
+ migrations.AddField(
25
+ model_name='query',
26
+ name='reply',
27
+ field=models.TextField(default='default', help_text='Unesite odgovor', max_length=1000),
28
+ preserve_default=False,
29
+ ),
30
+ migrations.AlterField(
31
+ model_name='language',
32
+ name='name',
33
+ field=models.CharField(help_text='Unesite jezik', max_length=16, unique=True),
34
+ ),
35
+ ]
bot/migrations/0004_param_alter_language_lid_alter_language_name.py ADDED
@@ -0,0 +1,48 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ # Generated by Django 5.0.3 on 2024-04-22 03:29
2
+
3
+ from django.db import migrations, models
4
+
5
+
6
+ class Migration(migrations.Migration):
7
+
8
+ dependencies = [
9
+ ('bot', '0003_rename_text_query_query_language_lid_query_reply_and_more'),
10
+ ]
11
+
12
+ operations = [
13
+ migrations.CreateModel(
14
+ name='Param',
15
+ fields=[
16
+ ('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
17
+ ('system', models.TextField(default='System prpmpt', help_text='Enter parameter value', max_length=2048)),
18
+ ('ctxpre', models.CharField(blank=True, help_text='Enter parameter value', max_length=80)),
19
+ ('msg_content', models.CharField(blank=True, help_text='Enter parameter value', max_length=80)),
20
+ ('min_len', models.IntegerField(default=40, help_text='Enter parameter value')),
21
+ ('CHUNK_SIZE', models.IntegerField(default=800, help_text='Enter parameter value')),
22
+ ('CHUNK_OVERLAP', models.IntegerField(default=50, help_text='Enter parameter value')),
23
+ ('max_results', models.IntegerField(default=3, help_text='Enter parameter value')),
24
+ ('EMBED_MODEL', models.CharField(default='embeddings model', help_text='Enter parameter value', max_length=256)),
25
+ ('model_id', models.CharField(default='LLM model', help_text='Enter parameter value', max_length=256)),
26
+ ('max_conv', models.IntegerField(default=3, help_text='Enter parameter value')),
27
+ ('min_distance', models.FloatField(default=0.35, help_text='Enter parameter value')),
28
+ ('max_distance', models.FloatField(default=0.6, help_text='Enter parameter value')),
29
+ ('temperature', models.FloatField(default=0.55, help_text='Enter parameter value')),
30
+ ('max_tokens', models.IntegerField(default=3072, help_text='Enter parameter value')),
31
+ ('top_p', models.FloatField(default=0.8, help_text='Enter parameter value')),
32
+ ('frequency_penalty', models.FloatField(default=0.0, help_text='Enter parameter value')),
33
+ ('presence_penalty', models.FloatField(default=0.0, help_text='Enter parameter value')),
34
+ ('DEBUG', models.BooleanField(default=True, help_text='Enter parameter value')),
35
+ ('jezik', models.CharField(default='srpski', help_text='Uneti jezik', max_length=16)),
36
+ ],
37
+ ),
38
+ migrations.AlterField(
39
+ model_name='language',
40
+ name='lid',
41
+ field=models.CharField(default='sr', help_text='Unesite kratak naziv jezika', max_length=2),
42
+ ),
43
+ migrations.AlterField(
44
+ model_name='language',
45
+ name='name',
46
+ field=models.CharField(default='srpski', help_text='Unesite jezik', max_length=16, unique=True),
47
+ ),
48
+ ]
bot/migrations/__init__.py ADDED
File without changes
bot/migrations/__pycache__/0001_initial.cpython-311.pyc ADDED
Binary file (1.02 kB). View file
 
bot/migrations/__pycache__/0002_query.cpython-311.pyc ADDED
Binary file (1.06 kB). View file
 
bot/migrations/__pycache__/0003_rename_text_query_query_language_lid_query_reply_and_more.cpython-311.pyc ADDED
Binary file (1.41 kB). View file
 
bot/migrations/__pycache__/0004_param_alter_language_lid_alter_language_name.cpython-311.pyc ADDED
Binary file (3.13 kB). View file
 
bot/migrations/__pycache__/__init__.cpython-311.pyc ADDED
Binary file (161 Bytes). View file
 
bot/models.py ADDED
@@ -0,0 +1,64 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ from django.db import models
2
+ from django.urls import reverse
3
+ from django.forms import ModelForm
4
+
5
+ class Query(models.Model):
6
+ query = models.TextField(
7
+ max_length=1000, help_text="Unesite upit")
8
+ reply = models.TextField(
9
+ max_length=1000, help_text="Unesite odgovor")
10
+ jezik = models.CharField(
11
+ max_length=16, help_text="Odaberite jezik!")
12
+ def get_absolute_url(self):
13
+ return reverse('query', args=[str(self.id)])
14
+ def __str__(self):
15
+ return self.text
16
+
17
+ #class QueryForm(ModelForm):
18
+ # class Meta:
19
+ # model = Query
20
+ # fields = ['query', 'reply', 'jezik']
21
+
22
+ class Language(models.Model):
23
+ name = models.CharField(max_length=16,
24
+ unique=True,
25
+ default="srpski",
26
+ help_text="Unesite jezik")
27
+ lid = models.CharField(max_length=2, unique=False, default="sr", help_text="Unesite kratak naziv jezika")
28
+ def get_absolute_url(self):
29
+ """Returns the url to access a particular language instance."""
30
+ return reverse('bot-detail', args=[str(self.id)])
31
+ def __str__(self):
32
+ """String for representing the Model object (in Admin site etc.)"""
33
+ return self.name
34
+
35
+ class LanguageForm(ModelForm):
36
+ class Meta:
37
+ model = Language
38
+ fields = ['name', 'lid']
39
+
40
+ class Param(models.Model):
41
+ system = models.TextField(max_length=2048, unique=False, blank=False, default="System prpmpt", help_text="Enter parameter value")
42
+ ctxpre = models.CharField(max_length=80, unique=False, blank=True, help_text="Enter parameter value")
43
+ msg_content = models.CharField(unique=False, blank=True, max_length=80, help_text="Enter parameter value")
44
+ min_len = models.IntegerField(unique=False, blank=False, default=40, help_text="Enter parameter value")
45
+ CHUNK_SIZE = models.IntegerField(unique=False, blank=False, default=800, help_text="Enter parameter value")
46
+ CHUNK_OVERLAP = models.IntegerField(unique=False, blank=False, default=50, help_text="Enter parameter value")
47
+ max_results = models.IntegerField(unique=False, blank=False, default=3, help_text="Enter parameter value")
48
+ EMBED_MODEL = models.CharField(max_length=256, default="embeddings model", help_text="Enter parameter value")
49
+ model_id = models.CharField(max_length=256, unique=False, default="LLM model", blank=False, help_text="Enter parameter value")
50
+ max_conv = models.IntegerField(unique=False, blank=False, default=3, help_text="Enter parameter value")
51
+ min_distance = models.FloatField(unique=False, blank=False, default=0.35, help_text="Enter parameter value")
52
+ max_distance = models.FloatField(unique=False, blank=False, default=0.6, help_text="Enter parameter value")
53
+ temperature = models.FloatField(unique=False, blank=False, default=0.55, help_text="Enter parameter value")
54
+ max_tokens = models.IntegerField(unique=False, blank=False, default=3072, help_text="Enter parameter value")
55
+ top_p = models.FloatField(unique=False, blank=False, default=0.8, help_text="Enter parameter value")
56
+ frequency_penalty = models.FloatField(unique=False, default=0.0, blank=False, help_text="Enter parameter value")
57
+ presence_penalty = models.FloatField(unique=False, default=0.0, blank=False, help_text="Enter parameter value")
58
+ DEBUG = models.BooleanField(unique=False, blank=False, default=True, help_text="Enter parameter value")
59
+ jezik = models.CharField(max_length=16, unique=False, blank=False, default="srpski", help_text="Uneti jezik")
60
+
61
+ class ParamModelForm(ModelForm):
62
+ class Meta:
63
+ model = Param
64
+ fields = [ 'system', 'ctxpre', 'msg_content', 'min_len', 'CHUNK_SIZE', 'CHUNK_OVERLAP', 'max_results', 'EMBED_MODEL', 'model_id', 'max_conv', 'min_distance', 'max_distance', 'temperature', 'max_tokens', 'top_p', 'frequency_penalty', 'presence_penalty', 'DEBUG', 'jezik']
bot/static/css/styles.css ADDED
@@ -0,0 +1,5 @@
 
 
 
 
 
 
1
+ .sidebar-nav {
2
+ margin-top: 20px;
3
+ padding: 0;
4
+ list-style: none;
5
+ }
bot/test.wsgi ADDED
@@ -0,0 +1,7 @@
 
 
 
 
 
 
 
 
1
+ def application(environ, start_response):
2
+ status = '200 OK'
3
+ output = b'Hello World!'
4
+ response_headers = [('Content-type', 'text/plain'),
5
+ ('Content-Length', str(len(output)))]
6
+ start_response(status, response_headers)
7
+ return [output]
bot/tests.py ADDED
@@ -0,0 +1,38 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ from django.test import TestCase
2
+
3
+ # Create your tests here.
4
+
5
+
6
+ from catalog.models import Language
7
+ from django.urls import reverse
8
+
9
+
10
+ class LanguageViewTest(TestCase):
11
+
12
+ @classmethod
13
+ def setUpTestData(cls):
14
+ langs = [ 'Hrvatski', 'Slovenački', 'Srpski', 'Bosanski', 'Makedonski', 'Bugarski']
15
+ for lang in langs:
16
+ l = Language.objects.create(name=lang) ; l.save()
17
+
18
+ import datetime
19
+ from django.utils import timezone
20
+
21
+ from bot.models import Language
22
+
23
+ # Get user model from settings
24
+ from django.contrib.auth import get_user_model
25
+ User = get_user_model()
26
+
27
+ class UserViewTest(TestCase):
28
+
29
+ def setUp(self):
30
+ # Create two users
31
+ test_user1 = User.objects.create_user(
32
+ username='testuser1', password='testuser1')
33
+ test_user2 = User.objects.create_user(
34
+ username='testuser2', password='testuser2')
35
+
36
+ test_user1.save()
37
+ test_user2.save()
38
+
bot/tests/__init__.py ADDED
@@ -0,0 +1 @@
 
 
1
+
bot/tests/__pycache__/__init__.cpython-311.pyc ADDED
Binary file (156 Bytes). View file
 
bot/tests/test_views.py ADDED
@@ -0,0 +1,38 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ from django.test import TestCase
2
+
3
+ # Create your tests here.
4
+
5
+
6
+ from catalog.models import Language
7
+ from django.urls import reverse
8
+
9
+
10
+ class LanguageViewTest(TestCase):
11
+
12
+ @classmethod
13
+ def setUpTestData(cls):
14
+ langs = [ 'Hrvatski', 'Slovenački', 'Srpski', 'Bosanski', 'Makedonski', 'Bugarski']
15
+ for lang in langs:
16
+ l = Language.objects.create(name=lang) ; l.save()
17
+
18
+ import datetime
19
+ from django.utils import timezone
20
+
21
+ from bot.models import Language
22
+
23
+ # Get user model from settings
24
+ from django.contrib.auth import get_user_model
25
+ User = get_user_model()
26
+
27
+ class UserViewTest(TestCase):
28
+
29
+ def setUp(self):
30
+ # Create two users
31
+ test_user1 = User.objects.create_user(
32
+ username='testuser1', password='testuser1')
33
+ test_user2 = User.objects.create_user(
34
+ username='testuser2', password='testuser2')
35
+
36
+ test_user1.save()
37
+ test_user2.save()
38
+
bot/uchat-old.py ADDED
@@ -0,0 +1,322 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ import chromadb
2
+ from chromadb.utils import embedding_functions
3
+ import os
4
+ from transformers import AutoModelForCausalLM, AutoTokenizer
5
+ import torch
6
+ from openai import OpenAI
7
+ from langchain_community.document_loaders import PyPDFLoader
8
+ from langchain.text_splitter import RecursiveCharacterTextSplitter
9
+ from itertools import islice, zip_longest
10
+ import re
11
+
12
+ #model_id = "mistralai/Mistral-7B-Instruct-v0.2"
13
+ #tokenizer = AutoTokenizer.from_pretrained(model_id)
14
+ model_id = "Yugo60-GPT-GGUF.Q4_K_M.gguf"
15
+
16
+ #inputs = tokenizer(text, return_tensors="pt").to(0)
17
+
18
+ #outputs = model.generate(**inputs, max_new_tokens=20)
19
+ #print(tokenizer.decode(outputs[0], skip_special_tokens=True))
20
+
21
+ if not torch.backends.mps.is_available():
22
+ if not torch.backends.mps.is_built():
23
+ print("MPS not available because the current PyTorch install was not "
24
+ "built with MPS enabled.")
25
+ else:
26
+ print("MPS not available because the current MacOS version is not 12.3+ "
27
+ "and/or you do not have an MPS-enabled device on this machine.")
28
+ else:
29
+ torch.set_default_device("mps")
30
+
31
+ model = ""
32
+ CHROMA_DATA_PATH = "chroma_data/"
33
+ EMBED_MODEL = "all-MiniLM-L6-v2"
34
+ # NousResearch/Hermes-2-Pro-Mistral-7B
35
+ # distilbert-base-multilingual-case
36
+ # paraphrase-multilingual-MiniLM-L12-v2d
37
+ COLLECTION_NAME = "chroma_data"
38
+ PDF_PATH = "./PDF/uputstvo_uz_eon_smart_box-1.pdf"
39
+ PDF_PATH2 = "./PDF/uputstvo_uz_eon_smart_aplikaciju-1.pdf"
40
+ CHUNK_SIZE = 800
41
+ CHUNK_OVERLAP = 50
42
+ max_results = 3
43
+ min_len = 40
44
+
45
+ def load_and_split_document(pdf_path):
46
+ loader = PyPDFLoader(pdf_path)
47
+ print('Loaded: ' + pdf_path)
48
+ return loader.load_and_split()
49
+
50
+ def split_text_into_chunks(pages, chunk_size, chunk_overlap):
51
+ n = -1
52
+ for page in range(len(pages)): pages[page].page_content = re.sub(r'\s+'," ", pages[page].page_content.replace(". .","").replace(r'\n','.')).replace('..','')
53
+ for p in range(len(pages)):
54
+ if len(pages[p].page_content)<min_len:
55
+ if n<0: n = p
56
+ else:
57
+ if n>=0:
58
+ pages[n]=pages[p]; n += 1
59
+ if n>0: pages = pages[:n-1]
60
+ text_splitter = RecursiveCharacterTextSplitter(chunk_size=chunk_size, chunk_overlap=chunk_overlap)
61
+ return text_splitter.split_documents(pages)
62
+
63
+ def batched(iterable, n):
64
+ it = iter(iterable)
65
+ while True:
66
+ batch = list(islice(it, n))
67
+ if not batch:
68
+ return
69
+ yield batch
70
+
71
+ client = chromadb.PersistentClient(path=CHROMA_DATA_PATH)
72
+ client.allow_reset = True
73
+ client.delete_collection(COLLECTION_NAME)
74
+
75
+ oc = OpenAI(base_url="http://localhost:4891/v1", api_key="not-needed")
76
+
77
+ docs = [
78
+ "s0", [
79
+ [
80
+ "",
81
+ "Navedite, da li je problem sa EON uređajem, upravljačem ili WiFi mrežom?",
82
+ "Problem sa TV odabirom sadržaja, prijemom signala ili dostupnošću usluga?",
83
+ "Problem sa naplatom usluga?",
84
+ ],
85
+ [ "s00", "Ako korisnik ima problema sa prijemom kablovskog signala ili slikom, proveriti EON SMART BOX uređaj", "Ako korisnik ima problem sa EON SMART BOX uređajem ili aplikacijom, treba proveriti EON podešavanja", "Ako je korisniku poptpuno crn ekran, proveriti resetovanje EON SMART BOX uređaja ili aplikacije" ],
86
+ [ "s01", "Ako nee radi internet korisniku, treba proveriti kablovski prijem", "Ako ne radi WiFi korisniku, onda proveriti priključen WiFI ruter" ],
87
+ [ "s02", "Ako korisnik ima problema sa izborom kanala, proveriti podešavanja ili pretplatu", "Ako ne radi daljinski upravljač, proveriti EON SMART BOX uređaj" ],
88
+ [ "s03", "Ako korisnik ima problema s plaćanjem pretplate, neka ga proveri ili izmiri na web stranici ili najbližoj filijali.", "Ako korisnik dobije poruku o neizmirenim obavezama na ekranu, neka proveri stanje pretplate na web strasnici ili u najbližoj filijali.", "Ako korisnik želi proveru stanja bez web stranice ili filijale, neka se obrati Call centru", "Ako korisnik želi naplatu obaveza ili promenu paketa usluga, neka se obrati Call centru." ],
89
+ ],
90
+ "s00", [
91
+ [
92
+ "Ako korisnik nije resetovao EON SMART BOX uređaj ili aplikaciju, neka pokuša da ga restartuje, kao i TV uređaj.",
93
+ "Ako problem korisniku nije rešen resetovanjem, onda ga uputiti na Call centar.",
94
+ ],
95
+ [ "s000", "Ako je resetovanje bilo uspešno, ali korisnik i dalje ima problem, neka se obrati call centru.", "Ako korisnik ne zna kako da resetuje uređaj, neka ga isključi iz struje na nekoliko sekundi, i ponovo uključi." ],
96
+ [ "s99", "Ako je korisniku nejasan odgovor, neka se obrati Call centru."],
97
+ ],
98
+ "s01", [
99
+ [
100
+ "Ako korisnik ima problema sa internetom, neka pokuša da restartuje WiFi ruter.",
101
+ "Ako se korisniku problem nastavlja i nakon resetovanja, neka pokuša sa resetovanje EON SMART BOX i WiFI uređaja.",
102
+ ],
103
+ [ "s010", "Ako korisnik ima problem sa prijemom kablovskog i internet signala, a resetovanje nije pomoglo, neka se obrati Call centru.", "Ako korisnik ima kablovski prijem, ali mu internet ne radi, neka proveri da li radim ping 8.8.8.8"],
104
+ [ "s00", "Ako korisnik ima kablovski prijem, ali internet ne radi, neka resetuje WiFI rutter", "Ako korisnuku rade TV kanali ali ne i internet, neka resetuje WiFI ruter", "Ako korisnik može gledati TV ali mu internet ne radi, neka resetuje WiFi ruter."],
105
+ [ "s99", "Ako je korisniku nejasan odgovor, neka se obrati Call centru." ],
106
+ ],
107
+ "s02", [
108
+ [
109
+ "Ako korisniku nisu dostpni samo pojedini kanali, neka proveri stanje pretplate.",
110
+ "Ako korisniku nije dostupna nijedna funkcija na daljinskom upravljaču, neka pokuša da promeni baterije ili daljinski upravljać.",
111
+ ],
112
+ [ "s03", "Ako korisnik želi da promeni paket usluga, neka se obrati Call centru.", "Ako korisnik želi da proveri stanje pretplate na svom računu, neka proveri stanje na web stranici ili preko Call centra." ],
113
+ [ "s99", "Ako je korisniku nejasan odgovor, neka se obrati Call centru." ],
114
+ ],
115
+ "s03", [
116
+ [
117
+ "Ako niste izmirili Vaše redovne obaveze, možete to učiniti online, ili putem najbližeg predstavništva.",
118
+ ],
119
+ [ "s99", "Ako je korisniku nejasan odgovor, neka se obrati Call centru." ],
120
+ ],
121
+ "s09", [
122
+ [
123
+ "Kontaktirajte Call centar za korisničku podrškua na 0800123123123",
124
+ ],
125
+ [ "s0", "Ako je korisniku nejasan odgovor, neka se obrati Call centru."]
126
+ ],
127
+ "s000", [
128
+ [
129
+ "Ako korisnik ne zna kako da resetuje uređaj ili aplikaciju, neka isključi uređaj iz struje, i nakon nekoliko sekundi ponovo ga uključi.",
130
+ ],
131
+ [ "s99", "Ako korisniku i dalje ima problem, neka se obrati Call centru.", "Ako korisnik ima novi problem, zahtevaj pojašnjenje." ],
132
+ ],
133
+ "s010", [
134
+ [
135
+ "Ako korisniku radi ping a ima problem sa internetom, neka pokuša da postavi u svom browser-u ili mrežnim podešavanjima korisničkog uređaja 8.8.8.8 kao DNS",
136
+ ],
137
+ [ "s99", "Ako se korisnik žali da mu nešto ne radi i dalje, uputite ga na Call centar", "Ako korisniku ne pomaže odgovor, neka se obrati Call centru." ],
138
+ ],
139
+ "s99", [
140
+ [
141
+ "Odgovorite korisniku na sledeći način isključivo: Žao mi je, ali ne mogu Vam pomoći. Kontaktirajte Call centar na 08001231231223"
142
+ ],
143
+ [ "s0", "Ako je korisniku nejasan odgovor, neka se obrati Call centru." ],
144
+ ]
145
+ ]
146
+
147
+ if not os.path.exists(CHROMA_DATA_PATH):
148
+ os.makedirs(CHROMA_DATA_PATH)
149
+
150
+ chroma_client = chromadb.PersistentClient(CHROMA_DATA_PATH)
151
+
152
+ embedding_func = embedding_functions.SentenceTransformerEmbeddingFunction(
153
+ model_name=EMBED_MODEL
154
+ )
155
+
156
+ collection = chroma_client.get_or_create_collection(
157
+ name="chroma_data",
158
+ embedding_function=embedding_func,
159
+ metadata={"hnsw:space": "cosine"},
160
+ )
161
+
162
+ #async function main() {
163
+ last = 0
164
+ state = -2
165
+ used =[]
166
+ for g in docs[0::2]:
167
+ state += 2
168
+ documents=docs[state+1][0]
169
+ collection.add(
170
+ documents=documents,
171
+ ids=[f"id{last+i}" for i in range(len(documents))],
172
+ metadatas=[{"state": g, "next": g, "used": False, "source": 'None', "page": -1 } for i in range(len(documents)) ]
173
+ )
174
+ for i in range(len(documents)): used += [0]
175
+ last += len(documents)
176
+ if (len(docs[state+1])>1):
177
+ for n in docs[state+1][1:]:
178
+ collection.add(
179
+ documents=n[1:],
180
+ ids=[f"id{last+i-1}" for i in range(1,len(n))],
181
+ metadatas=[{"state": g, "next": n[0], "used": False, "source": 'None', "page": -1 } for i in range(1,len(n)) ]
182
+ )
183
+ for i in range(1,len(n)): used += [0]
184
+ last += len(n)-1
185
+
186
+ state += 2
187
+ docus = load_and_split_document(PDF_PATH) + load_and_split_document(PDF_PATH2)
188
+
189
+ pages = split_text_into_chunks(docus, CHUNK_SIZE, CHUNK_OVERLAP)
190
+ document_indices = list(range(len(pages)))
191
+ for batch in batched(document_indices, 166):
192
+ collection.add(
193
+ ids=[f"id{last+batch[i]}" for i in range(len(batch))],
194
+ documents=[pages[i].page_content for i in batch],
195
+ metadatas=[dict(dict(dict(pages[i].metadata, used=False), next='None'), state='None') for i in batch],
196
+ )
197
+ last += len(batch)
198
+
199
+ msg = "Pomozite mi sa EON uslugama"
200
+ system_content = "Korisnik User ispod postavlja pitanje ili zadatak, upareno sa unosom koji pruža dodatni mogući kontekst. Napišite odgovor na srpskom jeziku, koji na odgovarajući način kompletira zahtev ili daje odgovor na pitanje. EON je deo usluga preduzeća United Group, koje uključuju i kablovsku mrežu za digitalnu televiziju, pristup internetu, uređaj EON SMART BOX za TV sadržaj, i fiksnu telefoniju. Korisnik se može obratiti Call centru telefonom na 080012341234, ili otiči do najbliže filijale ako mu ne pomaže odgovor."
201
+ #system_content = "Zoveš se Assistant. Ogovaraj ljubazno na pitanja i probleme koje postavlja korisnik koji se zove User."
202
+ #msg_content = "odgovori mi na ovo pitanje ili problem kroz sumiranje sledećih delova uputstava, od kojih se samo neka odnose na postavljeno pitanje ili problem: "
203
+ msg_content = "dodatni mogući kontekts je: "
204
+ ns = cs = "s0"
205
+ messages = context = []
206
+ reply = ctx = ""
207
+ print ("Recite kako Vam mogu pomoći ...")
208
+ ctx_flag = True
209
+ previous = ""
210
+ while True:
211
+ print()
212
+ show = False
213
+ msg = input("User> ")
214
+ print()
215
+ if msg=="###":
216
+ show = True
217
+ print("ctx: ", ctx, ", len=", len(context))
218
+ print("reply=", reply)
219
+ print("msg: ", messages)
220
+ msg = input("User> ")
221
+ print()
222
+ if msg=="###": break
223
+ query_results = collection.query(
224
+ query_texts = [ msg ],
225
+ n_results = max_results,
226
+ where = { "$and": [ { "$or": [ {"state": cs }, { "page": { "$nin": [ -1 ] } } ] } , { "used": False } ] }
227
+ )
228
+ ln = len(query_results["documents"])
229
+ ctx = ""
230
+ context = []
231
+ for n in range(ln):
232
+ context += query_results["documents"][n]
233
+ for n in range(len(context)):
234
+ ctx += context[n] + ", "
235
+ ctx = ctx[:-2]
236
+ if messages==[]:
237
+ messages=[
238
+ {"role": "system", "content": system_content},
239
+ {"role": "user", "content": f"{msg} - " + msg_content + ctx + "."}
240
+ ]
241
+ else:
242
+ if ctx_flag:
243
+ new_message = [
244
+ {"role": "user", "content": f"{msg}" + msg_content + ctx + "."}
245
+ ]
246
+ else:
247
+ new_message = [
248
+ # {"role": "system", "content": [system_content] + context},
249
+ # {"role": "user", "content": f"{msg}" + msg_content + ctx + "."}
250
+ {"role": "user", "content": msg + "."}
251
+ ]
252
+ messages.append(new_message)
253
+ if (ln==0):
254
+ collection.update(
255
+ ids=[f"id{id}" for id in range(collection.count())],
256
+ metadatas=[{"used": False} for i in range(collection.count())],
257
+ )
258
+ reply = "Kako Vam još mogu pomoći?"
259
+ ctx_flag = True
260
+ ns = cs = "s0"
261
+ elif query_results["documents"][0][0]=="###":
262
+ ctx_flag = False
263
+ else:
264
+ if (query_results["distances"][0][0] > 0.6):
265
+ ctx_flag = True
266
+ print("Malo je nejasno šta je problem..")
267
+ collection.update(
268
+ ids=[f"id{id}" for id in range(collection.count())],
269
+ metadatas=[{"used": False} for i in range(collection.count())],
270
+ )
271
+ reply = "Kako Vam još mogu pomoći?"
272
+ ns = cs = "s0"
273
+ else:
274
+ ctx_flag = False
275
+ reply=query_results["documents"][0][0]
276
+ id = query_results["ids"][0]
277
+ meta = query_results["metadatas"][0]
278
+ # ovo treba usloviti potrebnom input var ako treba
279
+ if (meta[0]["state"] not in ['None','s99']): meta[0]["used"] = True
280
+ collection.update( ids=id, metadatas=meta)
281
+ ns = query_results["metadatas"][0][0]["next"]
282
+ if show: print(cs, "->", ns)
283
+ if not(show):
284
+ print(f"Assistant({cs}): ")
285
+ else:
286
+ print(f"Assistant({cs}): ", query_results["documents"][0][0]) ; print(messages)
287
+ completion = oc.chat.completions.create(
288
+ model = model_id,
289
+ messages=messages,
290
+ temperature=0.6, #0.9
291
+ max_tokens=2048,
292
+ top_p=0.8, #0.2, 0.92
293
+ frequency_penalty=0.0, #0.05
294
+ presence_penalty=0.0, # 1.11
295
+ stop=None,
296
+ # do_sampe=True,
297
+ # stream=True
298
+ )
299
+ new_message = {"role": "assistant", "content": ""}
300
+ new=completion.choices[0].message.content
301
+ if new==previous:
302
+ new_message["content"] = reply
303
+ collection.update(
304
+ ids=[f"id{id}" for id in range(collection.count())],
305
+ metadatas=[{"used": False} for i in range(collection.count())],
306
+ )
307
+ previous = reply = "Kako Vam još mogu pomoći?"
308
+ printf (reply, end="", flush=True)
309
+ ns = cs = "s0"
310
+ messages=[]
311
+ else:
312
+ new_message["content"] += completion.choices[0].message.content
313
+ previous = new
314
+ print(new, end="", flush=True)
315
+ messages.append(new_message)
316
+ #messages=[]
317
+ if (ns!='None'):
318
+ if (ns != cs): cs=ns ; context = [] ; ctx = "" ; ctx_flag = True
319
+ if cs=='None': cs='s0' ; ctx_flag = False
320
+
321
+ print("Kraj.")
322
+
bot/uchat.py ADDED
@@ -0,0 +1,162 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ import chromadb
2
+ from chromadb.utils import embedding_functions
3
+ from .models import Param
4
+ import os
5
+ import torch
6
+ from openai import OpenAI
7
+ from langchain_community.document_loaders import PyPDFLoader
8
+ from langchain.text_splitter import RecursiveCharacterTextSplitter
9
+ from itertools import islice, zip_longest
10
+ import re
11
+
12
+ # model_id = "mistralai/Mistral-7B-Instruct-v0.2"
13
+ model_id = "Yugo60-GPT-GGUF.Q4_K_M.gguf"
14
+
15
+ #outputs = model.generate(**inputs, max_new_tokens=20)
16
+ #print(tokenizer.decode(outputs[0], skip_special_tokens=True))
17
+
18
+ if not torch.backends.mps.is_available():
19
+ if not torch.backends.mps.is_built():
20
+ print("MPS not available because the current PyTorch install was not "
21
+ "built with MPS enabled.")
22
+ else:
23
+ print("MPS not available because the current MacOS version is not 12.3+ "
24
+ "and/or you do not have an MPS-enabled device on this machine.")
25
+ else:
26
+ torch.set_default_device("mps")
27
+
28
+ model = ""
29
+ CHROMA_DATA_PATH = "/Users/zoranpopovic/uchat/chroma_data/"
30
+ EMBED_MODEL = "all-MiniLM-L6-v2"
31
+ # NousResearch/Hermes-2-Pro-Mistral-7B
32
+ # distilbert-base-multilingual-case
33
+ # paraphrase-multilingual-MiniLM-L12-v2d
34
+ COLLECTION_NAME = "chroma_data"
35
+ PDF_PATH = "./PDF/uputstvo_uz_eon_smart_box-1.pdf"
36
+ PDF_PATH2 = "./PDF/uputstvo_uz_eon_smart_aplikaciju-1.pdf"
37
+ CHUNK_SIZE = 800
38
+ CHUNK_OVERLAP = 50
39
+ max_results = 3
40
+ min_len = 40
41
+ min_distance = 0.35
42
+ max_distance = 0.6
43
+ temperature = 0.55
44
+ max_tokens=3072
45
+ top_p=0.8
46
+ frequency_penalty=0.0
47
+ presence_penalty=0.15
48
+ DEBUG = True
49
+ system_sr = "Zoveš se U-Chat AI asistent i pomažeš korisniku usluga kompanije United Group. Korisnik postavlja pitanje ili problem, upareno sa dodatnima saznanjima. Na osnovu toga napiši korisniku kratak i ljubazan odgovor koji kompletira njegov zahtev ili mu daje odgovor na pitanje. "
50
+ # " Ako ne znaš odgovor, reci da ne znaš, ne izmišljaj ga."
51
+ system_sr += "Usluge kompanije United Group uključuju i kablovsku mrežu za digitalnu televiziju, pristup internetu, uređaj EON SMART BOX za TV sadržaj, kao i fiksnu telefoniju."
52
+ system = {'srpski': system_sr, 'hrvatski': "", 'slovenački': "", 'makedonski': ""}
53
+ ctxpre = ""
54
+ msg_content = {'srpski': "- Dodatna saznanja su: ", 'hrvatski': "", 'slovenački': "", 'makedonski': ""}
55
+ max_conv = 3
56
+ try:
57
+ edit_all = Param.objects.all()
58
+ for edit in edit_all:
59
+ system[edit.jezik] = edit.system
60
+ ctxpre = edit.ctxpre
61
+ msg_content[edit.jezik] = edit.msg_content
62
+ min_len = edit.min_len
63
+ CHUNK_SIZE = edit.CHUNK_SIZE
64
+ CHUNK_OVERLAP = edit.CHUNK_OVERLAP
65
+ max_results = edit.max_results
66
+ EMBED_MODEL = edit.EMBED_MODEL
67
+ model_id = edit.model_id
68
+ min_distance = edit.min_distance
69
+ max_distance = edit.max_distance
70
+ max_conv = edit.max_conv
71
+ temperature = edit.temperature
72
+ top_p = edit.top_p
73
+ max_tokens = edit.max_tokens
74
+ presence_penalty = edit.presence_penalty
75
+ frequency_penalty = edit.frequency_penalty
76
+ DEBUG = edit.DEBUG
77
+ except:
78
+ pass
79
+
80
+ def load_and_split_document(pdf_path):
81
+ loader = PyPDFLoader(pdf_path)
82
+ print('Loaded: ' + pdf_path)
83
+ return loader.load_and_split()
84
+
85
+ def split_text_into_chunks(pages, chunk_size, chunk_overlap):
86
+ n = -1
87
+ for page in range(len(pages)): pages[page].page_content = re.sub(r'\s+'," ", pages[page].page_content.replace(". .","").replace(r'\n','.')).replace('..','')
88
+ for p in range(len(pages)):
89
+ if len(pages[p].page_content)<min_len:
90
+ if n<0: n = p
91
+ else:
92
+ if n>=0:
93
+ pages[n]=pages[p]; n += 1
94
+ if n>0: pages = pages[:n-1]
95
+ text_splitter = RecursiveCharacterTextSplitter(chunk_size=chunk_size, chunk_overlap=chunk_overlap)
96
+ return text_splitter.split_documents(pages)
97
+
98
+ def batched(iterable, n):
99
+ it = iter(iterable)
100
+ while True:
101
+ batch = list(islice(it, n))
102
+ if not batch:
103
+ return
104
+ yield batch
105
+
106
+ #client = chromadb.PersistentClient(path=CHROMA_DATA_PATH)
107
+ #client.allow_reset = True
108
+ #client.delete_collection(COLLECTION_NAME)
109
+ oc = OpenAI(base_url="http://localhost:4891/v1", api_key="not-needed")
110
+
111
+ chroma_client = chromadb.PersistentClient(CHROMA_DATA_PATH)
112
+
113
+ embedding_func = embedding_functions.SentenceTransformerEmbeddingFunction(
114
+ model_name=EMBED_MODEL
115
+ )
116
+
117
+ collection = chroma_client.get_or_create_collection(
118
+ name="chroma_data",
119
+ embedding_function=embedding_func,
120
+ metadata={"hnsw:space": "cosine"},
121
+ )
122
+
123
+ last = collection.count()
124
+
125
+ def update_collection(docs, last, jezik):
126
+ state = -2
127
+ used =[]
128
+ for g in docs[0::2]:
129
+ state += 2
130
+ documents=docs[state+1][0]
131
+ bot.uchat.collection.add(
132
+ documents=documents,
133
+ ids=[f"id{last+i}" for i in range(len(documents))],
134
+ metadatas=[{"state": g, "next": g, "used": False, "source": 'None', "page": -1, "lang": jezik } for i in range(len(documents)) ]
135
+ )
136
+ last += len(documents)
137
+ if (len(docs[state+1])>1):
138
+ for n in docs[state+1][1:]:
139
+ bot.uchat.collection.add(
140
+ documents=n[1:],
141
+ ids=[f"id{last+i-1}" for i in range(1,len(n))],
142
+ metadatas=[{"state": g, "next": n[0], "used": False, "source": 'None', "page": -1, "lang": jezik } for i in range(1,len(n)) ]
143
+ )
144
+ for i in range(1,len(n)): used += [0]
145
+ last += len(n)-1
146
+ return last
147
+
148
+ #docus = load_and_split_document(PDF_PATH) + load_and_split_document(PDF_PATH2)
149
+
150
+ def load_docs(path, jezik):
151
+ docus = load_and_split_document(path)
152
+ pages = split_text_into_chunks(docus, CHUNK_SIZE, CHUNK_OVERLAP)
153
+ document_indices = list(range(bot.uchat.last, bot.uchat.last+len(pages)))
154
+ for batch in batched(document_indices, 66):
155
+ bot.uchat.collection.add(
156
+ ids=[f"id{last+batch[i]}" for i in range(len(batch))],
157
+ documents=[pages[i].page_content for i in batch],
158
+ metadatas=[dict(dict(dict(dict(pages[i].metadata, used=False), next='None'), state='None'), lang=jezik) for i in batch],
159
+ )
160
+ last += len(batch)
161
+ return last
162
+
bot/urls.py ADDED
@@ -0,0 +1,31 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ from django.urls import path
2
+ from . import views
3
+ #from . import tests
4
+
5
+ urlpatterns = [
6
+ path('', views.index, name='index'),
7
+ path('bot/', views.editor, name='bot'),
8
+ ]
9
+
10
+ urlpatterns += [
11
+ path('reset/', views.reset, name='reset'),
12
+ ]
13
+
14
+ urlpatterns += [
15
+ path('languages/', views.BotView.as_view(), name='languages'),
16
+ path('language/<int:pk>', views.BotViewDetail.as_view(), name='bot-detail'),
17
+ path('bot/<int:pk>/<int:pk2>', views.editor_id, name='editor_id'),
18
+ path('params/', views.params, name='params'),
19
+ path('params/0', views.params_refresh, name='params-refresh'),
20
+ path('importpdf', views.importPdf, name='importpdf'),
21
+ # path('bot/create', views.editor_create, name='editor_create'),
22
+ # path('bot/delete', views.editor_delete, name='editor_delete'),
23
+ ]
24
+
25
+ #urlpatterns += [
26
+ # path('tests/', views.LanguageViewTest.as_view(), name='tests'),
27
+ #]
28
+
29
+ #urlpatterns += [
30
+ # path('tests/', views.UserViewTest.as_view(), name='tests'),
31
+ #]
bot/views.py ADDED
@@ -0,0 +1,624 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ import bot.uchat
2
+ from django.shortcuts import render
3
+ from .models import Language, Query, ParamModelForm, Param
4
+ from bot.forms import RenewBotForm, EditorForm, EditorListForm, ParamForm, ImportForm
5
+ from django.shortcuts import get_object_or_404
6
+ from django.http import HttpResponseRedirect
7
+ from django.urls import reverse
8
+ import datetime
9
+ from django.db import transaction
10
+ from openai import OpenAI
11
+ from django.contrib.auth.decorators import login_required, permission_required
12
+ import json
13
+
14
+ #bot.uchat.chroma_client.allow_reset = True
15
+
16
+ class chat(object):
17
+ ns = cs = "s0"
18
+ reply = ctx = ""
19
+ messages = context = []
20
+ ctx_flag = True
21
+ previous = ""
22
+ oc = bot.uchat.oc
23
+ def get_reply(self,jezik,query,max_results,flag):
24
+ msg = query # + "Objasnite na " + jezik + ", "
25
+ query_results = bot.uchat.collection.query(
26
+ query_texts = [ msg ],
27
+ n_results = max_results,
28
+ where = { "$and": [ {"$and": [ { "$or": [ {"state": self.cs }, { "page": { "$nin": [ -1 ] } } ] } , { "used": False } ] } ,
29
+ {"lang": jezik } ] },
30
+ )
31
+ if bot.uchat.DEBUG: print("Query results:\n", query_results, "jezik:", jezik)
32
+ ln = len(query_results["documents"][0])
33
+ if ln == 0:
34
+ if bot.uchat.DEBUG: print("Odaberite drugi jezik")
35
+ bot.uchat.collection.update(
36
+ ids=[f"id{id}" for id in range(bot.uchat.collection.count())],
37
+ metadatas=[{"used": False} for i in range(bot.uchat.collection.count())],
38
+ )
39
+ if len(self.messages)>0: self.messages = self.messages[0]
40
+ new = reply = "Kako Vam još mogu pomoći?"
41
+ self.ctx_flag = True
42
+ self.ns = self.cs = "s0"
43
+ return new
44
+ else:
45
+ context = []
46
+ i_state = l_state = -1
47
+ for n in range(ln):
48
+ if query_results["distances"][0][n] < (0.05+(bot.uchat.max_distance+bot.uchat.min_distance)/2):
49
+ context += [ query_results["documents"][0][n] ]
50
+ if i_state<0:
51
+ l_state += 1
52
+ if query_results["metadatas"][0][n]['state'] != 'None':
53
+ i_state = n
54
+ else:
55
+ if (query_results["metadatas"][0][n]['state'] != 'None') and (i_state<0):
56
+ i_state = n
57
+ if l_state<0:
58
+ l_state = i_state = 0
59
+ ctx = query_results["documents"][0][0]
60
+ if self.cs != 'None':
61
+ for n in range(1,len(context)): ctx += ", " + context[n]
62
+ else:
63
+ ctx = context[l_state]
64
+ for n in range(len(context)):
65
+ if l_state != n:
66
+ ctx += ", " + context[n]
67
+ ctx += "."
68
+ match jezik:
69
+ case 'hrvatski':
70
+ o_jezik = 'hrvatskom'
71
+ case 'slovenački':
72
+ o_jezik = 'slovenačkom'
73
+ case 'srpski':
74
+ o_jezik = 'srpskom'
75
+ case 'makedonski':
76
+ o_jezik = 'makedonskom'
77
+ if query_results["documents"][0][i_state]=="###":
78
+ self.ctx_flag = False
79
+ new = reply = "Kako Vam još mogu pomoći?"
80
+ if bot.uchat.DEBUG: print("!!!###!!!")
81
+ return "Ne razumem, ili je u pitanju greška."
82
+ else:
83
+ if ((query_results["distances"][0][i_state] > bot.uchat.max_distance)) and (self.cs == 'None'):
84
+ self.ctx_flag = False
85
+ if bot.uchat.DEBUG: print("Malo je nejasno šta je problem..")
86
+ bot.uchat.collection.update(
87
+ ids=[f"id{id}" for id in range(bot.uchat.collection.count())],
88
+ metadatas=[{"used": False} for i in range(bot.uchat.collection.count())],
89
+ )
90
+ if len(messages)>0: messsages = messages[0]
91
+ reply = "Malo je nejasno šta je problem - kako Vam još mogu pomoći?"
92
+ self.ns = self.cs = "s0"
93
+ return reply
94
+ elif (query_results["distances"][0][i_state] < bot.uchat.min_distance):
95
+ if self.cs != "None":
96
+ self.ctx_flag = False
97
+ else:
98
+ self.ctx_flag = True
99
+ new = reply=query_results["documents"][0][i_state]
100
+ else:
101
+ self.ctx_flag = True
102
+ # reply=query_results["documents"][0][i_state]
103
+ if (len(msg) < bot.uchat.min_len/4) or flag: self.ctx_flag = False
104
+ id = query_results["ids"][0]
105
+ meta = query_results["metadatas"][0]
106
+ # ovo treba usloviti potrebnom input var ako treba
107
+ if (meta[i_state]["state"] not in ['','s99']): meta[0]["used"] = True
108
+ bot.uchat.collection.update( ids=id, metadatas=meta)
109
+ self.ns = query_results["metadatas"][0][i_state]["next"]
110
+ if self.messages==[]:
111
+ self.messages = [ {"role": "system", "content": bot.uchat.system[jezik]} ]
112
+ new_message = {"role": "user", "content": f"{msg} " + bot.uchat.msg_content[jezik] + " " + ctx + ". "}
113
+ else:
114
+ if self.ctx_flag:
115
+ new_message = {"role": "user", "content": f"{msg}. " + bot.uchat.msg_content[jezik] + " " + ctx + ". "}
116
+ else:
117
+ new_message = {"role": "user", "content": f"{msg}."}
118
+ self.messages.append(new_message)
119
+ print("messages=", self.messages)
120
+ if query_results["distances"][0][i_state] > bot.uchat.min_distance:
121
+ completion = bot.uchat.oc.chat.completions.create(
122
+ model = bot.uchat.model_id,
123
+ messages=self.messages,
124
+ temperature=bot.uchat.temperature,
125
+ max_tokens=bot.uchat.max_tokens,
126
+ top_p=bot.uchat.top_p,
127
+ frequency_penalty=bot.uchat.frequency_penalty,
128
+ presence_penalty=bot.uchat.presence_penalty,
129
+ stop=["###","<|","|im_end|","|im_start|"],
130
+ # do_sample=True,
131
+ )
132
+ if bot.uchat.DEBUG: print('msg=' + new_message['content'] + "\nMessages:\n", self.messages, flush=True)
133
+ new_message = {"role": "assistant", "content": ""}
134
+ new=completion.choices[0].message.content
135
+ if new==self.previous:
136
+ if bot.uchat.DEBUG: print("Same!!!")
137
+ bot.uchat.collection.update(
138
+ ids=[f"id{id}" for id in range(bot.uchat.collection.count())],
139
+ metadatas=[{"used": False} for i in range(bot.uchat.collection.count())],
140
+ )
141
+ new_message["content"] = new = self.previous = reply = "Kako Vam još mogu pomoći?"
142
+ self.ns = self.cs = "s0"
143
+ self.messages = self.messages[0]
144
+ else:
145
+ new_message["content"] += completion.choices[0].message.content
146
+ self.previous = new_message["content"]
147
+ if bot.uchat.DEBUG: print(new, end="", flush=True)
148
+ else:
149
+ new_message = {"role": "assistant", "content": ""}
150
+ new_message["content"] = reply
151
+ new = reply
152
+ self.messages.append(new_message)
153
+ # Prevođenje na druge jezike:
154
+ #match o_jezik:
155
+ # case 'srpskom':
156
+ # pass
157
+ # case _ :
158
+ # new_message = {"role": "user", "content": f"Napiši to na {o_jezik} jeziku."}
159
+ # self.messages.append(new_message)
160
+ # completion = bot.uchat.oc.chat.completions.create(
161
+ # model = bot.uchat.model_id,
162
+ # messages=self.messages,
163
+ # temperature=bot.uchat.temperature,
164
+ # max_tokens=bot.uchat.max_tokens,
165
+ # top_p=bot.uchat.top_p,
166
+ # frequency_penalty=bot.uchat.frequency_penalty,
167
+ # presence_penalty=bot.uchat.presence_penalty,
168
+ # stop=None,
169
+ # # do_sample=True,
170
+ # )
171
+ # new=completion.choices[0].message.content
172
+ # new_message = {"role": "user", "content": new}
173
+ # self.messages.append(new_message)
174
+ if (self.ns!='None'):
175
+ if (self.ns != self.cs): self.cs=self.ns
176
+ if self.cs=='None': self.cs='s0' ; self.ctx_flag = False
177
+ return new
178
+
179
+ def selected(jez,str):
180
+ if jez==str:
181
+ return 'selected'
182
+ else:
183
+ return ' '
184
+
185
+ def index(request):
186
+ #num_books = Book.objects.all().count()
187
+ # Number of visits to this view, as counted in the session variable.
188
+ chat_inst = chat()
189
+ request.session.set_expiry(300)
190
+ jezik = request.session.get('jezik', 'srpski')
191
+ num_visits = request.session.get('num_visits', 1)
192
+ if num_visits == 0:
193
+ if bot.uchat.DEBUG: print("Debug: ")
194
+ request.session['num_visits'] = num_visits+1
195
+ reply = request.session.get("replies", "Zdravo, kako Vam mogu pomoći?")
196
+ if request.method == 'POST':
197
+ # Create a form instance and populate it with data from the request (binding):
198
+ form = RenewBotForm(request.POST)
199
+ if form.is_valid():
200
+ request.session['query'] = query = form.cleaned_data['query']
201
+ jezik = form.cleaned_data['jezik']
202
+ request.session['jezik'] = jezik
203
+ nr = bot.uchat.max_results if num_visits < bot.uchat.max_results else 1+(num_visits % 2)
204
+ #iif len(chat_inst.messages)>0:
205
+ # request.session['messages'] = chat_inst.messages if num_visits % 2 == 1 else chat_inst.messages[0:0]
206
+ chat_inst.messages = request.session.get('messages',[])
207
+ chat_inst.cs = request.session.get('cs','s0')
208
+ chat_inst.ns = request.session.get('ns','s0')
209
+ if bot.uchat.max_conv < len(chat_inst.messages):
210
+ new_reply = chat_inst.get_reply(jezik, query, nr, True)
211
+ else:
212
+ new_reply = chat_inst.get_reply(jezik, query, nr, False)
213
+ request.session['messages'] = chat_inst.messages
214
+ request.session['ns'] = chat_inst.ns
215
+ request.session['cs'] = chat_inst.cs
216
+ request.session['replies'] = reply + "\nKorisnik: " + query + "\n\nOdgovor: " + new_reply + "\n"
217
+ # q = QueryForm(request.POST)
218
+ return HttpResponseRedirect(reverse("index"))
219
+ else:
220
+ if bot.uchat.DEBUG: print("Invalid form!", form.errors)
221
+ else:
222
+ form = RenewBotForm(initial={'query': 'Neki upit:'})
223
+ query = request.session.get('query','...')
224
+ jezik = request.session.get('jezik','srpski')
225
+ #if len(chat_inst.messages)>0:
226
+ # request.session['messages'] = chat_inat.messages
227
+ #else:
228
+ # request.session['messages'] = []
229
+ return render(
230
+ request,
231
+ 'index.html',
232
+ context={
233
+ 'num_visits': num_visits,
234
+ 'reply': reply,
235
+ 'selected_hr': selected(jezik,'hrvatski'),
236
+ 'selected_sl': selected(jezik,'slovenački'),
237
+ 'selected_sr': selected(jezik,'srpski'),
238
+ 'selected_mk': selected(jezik,'makedonski'),
239
+ }
240
+ )
241
+
242
+ def reset(request):
243
+ chat().messages = request.session.get('messages',[])
244
+ chat().cs = "s0"
245
+ chat().ns = "s0"
246
+ chat().oc.close()
247
+ bot.uchat.oc = oc = OpenAI(base_url="http://localhost:4891/v1", api_key="not-needed")
248
+ ids = bot.uchat.collection.get()['ids']
249
+ for id in ids: bot.uchat.collection.update(ids=[id], metadatas=[{'used': False}])
250
+ jezik = request.session.get('jezik','srpski')
251
+ request.session.flush()
252
+ request.session['num_visits'] = 0
253
+ return render(
254
+ request,
255
+ 'index.html',
256
+ context = {'num_visits': 0,
257
+ 'reply': 'Kako Vam mogu još pomoći?',
258
+ 'selected_hr': selected(jezik,'hrvatski'),
259
+ 'selected_sl': selected(jezik,'slovenački'),
260
+ 'selected_sr': selected(jezik,'srpski'),
261
+ 'selected_mk': selected(jezik,'makedonski'),
262
+ }
263
+ )
264
+
265
+ def editor(request):
266
+ #pagesize = 10
267
+ if request.method == "POST":
268
+ form = EditorListForm(request.POST)
269
+ form.is_valid()
270
+ try:
271
+ request.session['id'] = f_id = form.cleaned_data['f_id']
272
+ except:
273
+ request.session['id'] = f_id = ""
274
+ try:
275
+ request.session['state'] = f_state = form.cleaned_data['f_state']
276
+ except:
277
+ request.session['state'] = f_state = ""
278
+ try:
279
+ request.session['next'] = f_next = form.cleaned_data['f_next']
280
+ except:
281
+ request.session['next'] = f_next = ""
282
+ try:
283
+ request.session['page'] = f_page = form.cleaned_data['f_page']
284
+ except:
285
+ request.session['page'] = f_page = ""
286
+ try:
287
+ request.session['jezik'] = f_jezik = form.cleaned_data['f_jezik']
288
+ except:
289
+ request.session['jezik'] = f_jezik = ""
290
+ try:
291
+ request.session['docu'] = f_docu = form.cleaned_data['f_docu']
292
+ except:
293
+ request.session['docu'] = f_docu = ""
294
+ return HttpResponseRedirect(reverse('bot'))
295
+ else:
296
+ f_jezik = jezik = request.session.get('jezik','')
297
+ f_state = request.session.get('state','')
298
+ f_next = request.session.get('next','')
299
+ f_page = request.session.get('page','')
300
+ f_docu = request.session.get('docu','')
301
+ f_id = request.session.get('id','')
302
+ meta = {}
303
+ if f_state != "":
304
+ meta = {"state": f_state}
305
+ if f_next != "":
306
+ if meta == {}:
307
+ meta = {"next": f_next}
308
+ else:
309
+ meta = { "$and": [ meta, {"next": f_next} ] }
310
+ if f_page !="":
311
+ if meta == {}:
312
+ meta = {"page": f_page}
313
+ else:
314
+ meta = { "$and": [ meta , {"page": f_page} ] }
315
+ if f_jezik != "":
316
+ if meta == {}:
317
+ meta = {"lang": f_jezik}
318
+ else:
319
+ meta = { "$and": [ meta, {"lang": f_jezik} ] }
320
+ if f_id == "":
321
+ if f_docu =="":
322
+ ids = bot.uchat.collection.get(where=meta)['ids']
323
+ documents = bot.uchat.collection.get(where=meta)['documents']
324
+ states = bot.uchat.collection.get(where=meta)['metadatas']
325
+ else:
326
+ ids = bot.uchat.collection.get(where=meta, where_document={"$contains": f_docu })['ids']
327
+ documents = bot.uchat.collection.get(where=meta, where_document={"$contains": f_docu })['documents']
328
+ states = bot.uchat.collection.get(where=meta, where_document={"$contains": f_docu })['metadatas']
329
+ else:
330
+ if f_docu == "":
331
+ ids = bot.uchat.collection.get(ids=[f'id{f_id}'], where=meta)['ids']
332
+ documents = bot.uchat.collection.get(ids=[f'id{f_id}'], where=meta)['documents']
333
+ states = bot.uchat.collection.get(ids=[f'id{f_id}'], where=meta)['metadatas']
334
+ else:
335
+ ids = bot.uchat.collection.get(ids=[f'id{f_id}'], where=meta, where_document={"$contains": f_docu })['ids']
336
+ documents = bot.uchat.collection.get(ids=[f'id{f_id}'], where=meta, where_document={"$contains": f_docu })['documents']
337
+ states = bot.uchat.collection.get(ids=[f'id{f_id}'], where=meta, where_document={"$contains": f_docu })['metadatas']
338
+ cnt = 0
339
+ nr = len(documents)
340
+ id_docs = []
341
+ for doc in documents:
342
+ try:
343
+ lang = states[cnt]['lang']
344
+ except:
345
+ lang = "srpski"
346
+ id_docs += [ [ids[cnt], states[cnt]['state'], states[cnt]['next'], states[cnt]['page'], lang, doc] ]
347
+ cnt += 1
348
+ id_docs.sort(key=lambda k: eval(k[0][2:]))
349
+ return render(
350
+ request,
351
+ 'index_editor.html',
352
+ context = {'last': bot.uchat.last, 'nr': nr,
353
+ 'id_docs': id_docs,
354
+ 'documents': documents,
355
+ 'id': "",
356
+ 'selected_hr': selected(jezik,'hrvatski'),
357
+ 'selected_sl': selected(jezik,'slovenački'),
358
+ 'selected_sr': selected(jezik,'srpski'),
359
+ 'selected_mk': selected(jezik,'makedonski'),
360
+ 'f_id': f_id,
361
+ 'f_state': f_state,
362
+ 'f_next': f_next,
363
+ 'f_page': f_page,
364
+ 'f_docu': f_docu,
365
+ 'f_jezik': f_jezik,
366
+ }
367
+ )
368
+
369
+ def get_id(coll):
370
+ for i in range(coll.count()):
371
+ id = coll.get(ids=f'id{i}')['ids']
372
+ if id==[]:
373
+ return i
374
+ return coll.count()
375
+
376
+ def editor_id(request, pk, pk2):
377
+ last = bot.uchat.last
378
+ state = next = uris = ""
379
+ used = False
380
+ page = -1
381
+ if request.method == "POST":
382
+ form = EditorForm(request.POST)
383
+ if form.is_valid():
384
+ id = form.cleaned_data['id'][2:]
385
+ state = form.cleaned_data['state']
386
+ next = form.cleaned_data['next']
387
+ used = json.loads(form.cleaned_data['used'].lower())
388
+ page = form.cleaned_data['page']
389
+ docu = form.cleaned_data['docu']
390
+ source = form.cleaned_data['source']
391
+ jezik = form.cleaned_data['jezik']
392
+ #request.session['jezik'] = jezik
393
+ meta = {'state': state, 'next': next, 'used': used, 'page': page, 'source': source, 'lang': jezik}
394
+ try:
395
+ if pk2==0:
396
+ bot.uchat.collection.update(
397
+ ids = f'id{pk}',
398
+ metadatas = meta,
399
+ documents = docu
400
+ )
401
+ return HttpResponseRedirect(reverse('bot')+f'{pk}/0')
402
+ elif pk2==1:
403
+ if bot.uchat.last>1:
404
+ new = get_id(bot.uchat.collection)
405
+ bot.uchat.collection.add(
406
+ ids = f'id{new}',
407
+ metadatas = meta,
408
+ documents = docu
409
+ )
410
+ bot.uchat.last += 1
411
+ return HttpResponseRedirect(reverse('bot')+f'{new}/0')
412
+ elif pk2==2:
413
+ bot.uchat.collection.delete(ids = f'id{pk}')
414
+ bot.uchat.last -= 1
415
+ return HttpResponseRedirect(reverse('bot'))
416
+ except:
417
+ if bot.uchat.DEBUG: print("Errors:", form.errors)
418
+ return HttpResponseRedirect(reverse('bot'))
419
+ else:
420
+ if bot.uchat.DEBUG: print("Invalid form!", form.errors)
421
+ return HttpResponseRedirect(reverse('bot')+f'{pk}/0')
422
+ else:
423
+ if last>0:
424
+ doc = bot.uchat.collection.get(ids=[f'id{pk}'])
425
+ state = doc['metadatas'][0]['state']
426
+ next = doc['metadatas'][0]['next']
427
+ used = doc['metadatas'][0]['used']
428
+ page = doc['metadatas'][0]['page']
429
+ docu = doc['documents'][0]
430
+ source = doc['metadatas'][0]['source']
431
+ try:
432
+ jezik = doc['metadatas'][0]['lang']
433
+ except:
434
+ jezik = request.session.get('jezik','srpski')
435
+ return render(
436
+ request,
437
+ 'index_editor.html',
438
+ context = {'last': bot.uchat.last, 'nr': "",
439
+ 'state': state,
440
+ 'next': next,
441
+ 'used': used,
442
+ 'page': page,
443
+ 'docu': docu,
444
+ 'source': source,
445
+ 'id': pk,
446
+ 'selected_hr': selected(jezik,'hrvatski'),
447
+ 'selected_sl': selected(jezik,'slovenački'),
448
+ 'selected_sr': selected(jezik,'srpski'),
449
+ 'selected_mk': selected(jezik,'makedonski'),
450
+ }
451
+ )
452
+
453
+ def params_refresh(request):
454
+ if request.method == "POST":
455
+ form = ParamForm(request.POST)
456
+ form.is_valid()
457
+ request.session["jezik"] = form.cleaned_data['jezik']
458
+ return HttpResponseRedirect(reverse('params'))
459
+ else:
460
+ return HttpResponseRedirect(reverse('params'))
461
+
462
+ def params(request):
463
+ if request.method == "POST":
464
+ form = ParamForm(request.POST)
465
+ jezici = []
466
+ edit_all = Param.objects.all()
467
+ for edit in edit_all: jezici += [edit.jezik]
468
+ mform = ParamModelForm(request.POST)
469
+ try:
470
+ form.is_valid()
471
+ request.session["jezik"] = form.cleaned_data['jezik']
472
+ jezik = request.session["jezik"]
473
+ bot.uchat.ctxpre = form.cleaned_data['ctxpre']
474
+ except:
475
+ bot.uchat.ctxpre = ""
476
+ try:
477
+ bot.uchat.msg_content[jezik] = form.cleaned_data['msg_content']
478
+ except:
479
+ bot.uchat.msg_content[jezik] = ""
480
+ try:
481
+ bot.uchat.system[jezik] = form.cleaned_data['system']
482
+ bot.uchat.min_len = form.cleaned_data['min_len']
483
+ bot.uchat.CHUNK_SIZE = form.cleaned_data['CHUNK_SIZE']
484
+ bot.uchat.CHUNK_OVERLAP = form.cleaned_data['CHUNK_OVERLAP']
485
+ bot.uchat.max_results = form.cleaned_data['max_results']
486
+ bot.uchat.EMBED_MODEL = form.cleaned_data['EMBED_MODEL']
487
+ bot.uchat.model_id = form.cleaned_data['model_id']
488
+ bot.uchat.max_conv = form.cleaned_data['max_conv']
489
+ bot.uchat.min_distance = form.cleaned_data['min_distance']
490
+ bot.uchat.max_distance = form.cleaned_data['max_distance']
491
+ bot.uchat.temperature = form.cleaned_data['temperature']
492
+ bot.uchat.max_tokens = form.cleaned_data['max_tokens']
493
+ bot.uchat.top_p = form.cleaned_data['top_p']
494
+ bot.uchat.frequency_penalty = form.cleaned_data['frequency_penalty']
495
+ bot.uchat.presence_penalty = form.cleaned_data['presence_penalty']
496
+ bot.uchat.DEBUG = json.loads(form.cleaned_data['DEBUG'].lower())
497
+ except:
498
+ if bot.uchat.DEBUG: print("Errors:", form.errors)
499
+ if jezik in jezici:
500
+ for edit in edit_all:
501
+ if edit.jezik == jezik:
502
+ edit.system = bot.uchat.system[jezik]
503
+ edit.min_len = bot.uchat.min_len
504
+ edit.CHUNK_SIZE = bot.uchat.CHUNK_SIZE
505
+ edit.CHUNK_OVERLAP = bot.uchat.CHUNK_OVERLAP
506
+ edit.max_results = bot.uchat.max_results
507
+ edit.EMBED_MODEL = bot.uchat.EMBED_MODEL
508
+ edit.model_id = bot.uchat.model_id
509
+ edit.max_conv = bot.uchat.max_conv
510
+ edit.min_distance = bot.uchat.min_distance
511
+ edit.max_distance = bot.uchat.max_distance
512
+ edit.temperature = bot.uchat.temperature
513
+ edit.max_tokens = bot.uchat.max_tokens
514
+ edit.top_p = bot.uchat.top_p
515
+ edit.frequency_penalty = bot.uchat.frequency_penalty
516
+ edit.presence_penalty = bot.uchat.presence_penalty
517
+ edit.DEBUG = bot.uchat.DEBUG
518
+ edit.jezik = jezik
519
+ edit.msg_content = bot.uchat.msg_content[jezik]
520
+ edit.ctxpre = bot.uchat.ctxpre
521
+ edit.save()
522
+ else:
523
+ mform.save()
524
+ return HttpResponseRedirect(reverse('params'))
525
+ else:
526
+ jezik = request.session.get('jezik','srpski')
527
+ if jezik == '': jezik='srpski'
528
+ edit_all = Param.objects.all()
529
+ for edit in edit_all:
530
+ if edit.jezik == jezik:
531
+ bot.uchat.system[jezik] = edit.system
532
+ bot.uchat.ctxpre = edit.ctxpre
533
+ bot.uchat.msg_content[jezik] = edit.msg_content
534
+ bot.uchat.min_len = edit.min_len
535
+ bot.uchat.CHUNK_SIZE = edit.CHUNK_SIZE
536
+ bot.uchat.CHUNK_OVERLAP = edit.CHUNK_OVERLAP
537
+ bot.uchat.max_results = edit.max_results
538
+ bot.uchat.EMBED_MODEL = edit.EMBED_MODEL
539
+ bot.uchat.model_id = edit.model_id
540
+ bot.uchat.min_distance = edit.min_distance
541
+ bot.uchat.max_distance = edit.max_distance
542
+ bot.uchat.max_conv = edit.max_conv
543
+ bot.uchat.temperature = edit.temperature
544
+ bot.uchat.top_p = edit.top_p
545
+ bot.uchat.max_tokens = edit.max_tokens
546
+ bot.uchat.presence_penalty = edit.presence_penalty
547
+ bot.uchat.frequency_penalty = edit.frequency_penalty
548
+ bot.uchat.DEBUG = edit.DEBUG
549
+ return render(
550
+ request,
551
+ 'index_params.html',
552
+ context = {'system': bot.uchat.system[jezik],
553
+ 'ctrpre': bot.uchat.ctxpre,
554
+ 'msg_content': bot.uchat.msg_content[jezik],
555
+ 'min_len': bot.uchat.min_len,
556
+ 'CHUNK_SIZE': bot.uchat.CHUNK_SIZE,
557
+ 'CHUNK_OVERLAP': bot.uchat.CHUNK_OVERLAP,
558
+ 'max_results': bot.uchat.max_results,
559
+ 'EMBED_MODEL': bot.uchat.EMBED_MODEL, # "all-MiniLM-L6-v2",
560
+ 'model_id': bot.uchat.model_id, # model_id = "Yugo60-GPT-GGUF.Q4_K_M.gguf"
561
+ 'max_conv': bot.uchat.max_conv,
562
+ 'min_distance': bot.uchat.min_distance,
563
+ 'max_distance': bot.uchat.max_distance,
564
+ 'temperature': bot.uchat.temperature,
565
+ 'max_tokens': bot.uchat.max_tokens,
566
+ 'top_p': bot.uchat.top_p,
567
+ 'frequency_penalty': bot.uchat.frequency_penalty,
568
+ 'presence_penalty': bot.uchat.presence_penalty,
569
+ 'DEBUG': bot.uchat.DEBUG,
570
+ 'selected_hr': selected(jezik,'hrvatski'),
571
+ 'selected_sl': selected(jezik,'slovenački'),
572
+ 'selected_sr': selected(jezik,'srpski'),
573
+ 'selected_mk': selected(jezik,'makedonski'),
574
+ }
575
+ )
576
+
577
+ def importPdf(request):
578
+ if request.method == "POST":
579
+ form = ImportForm(request.POST)
580
+ if form.is_valid():
581
+ path = form.cleaned_data['path']
582
+ jezik = form.cleaned_data['jezik']
583
+ request.session['jezik'] = jezik
584
+ request.session['path'] = path
585
+ l_last = bot.uchat.last
586
+ try:
587
+ bot.uchat.load_docs(path, jezik)
588
+ l_last = bot.uchat.last - l_last
589
+ request.session['answer'] = f"Importovano {l_last} delova PDF dokumenta."
590
+ except:
591
+ if bot.uchat.DEBUG: print("Došlo je do problema sa importom PDF fajla.")
592
+ request.session['answer'] = "Došlo je do problema sa importom PDF fajla."
593
+ return HttpResponseRedirect(reverse('importpdf'))
594
+ else:
595
+ jezik = request.session.get('jezik','srpski')
596
+ path = request.session.get('path','/Users/profile/...')
597
+ answer = request.session.get('answer','')
598
+ return render(
599
+ request,
600
+ 'index_import.html',
601
+ context = {'path': path,
602
+ 'answer': answer,
603
+ 'selected_hr': selected(jezik,'hrvatski'),
604
+ 'selected_sl': selected(jezik,'slovenački'),
605
+ 'selected_sr': selected(jezik,'srpski'),
606
+ 'selected_mk': selected(jezik,'makedonski'),
607
+ }
608
+ )
609
+
610
+ from django.views import generic
611
+
612
+ class BotView(generic.ListView):
613
+ """View for a bot chat."""
614
+ if bot.uchat.DEBUG: print ("Test!")
615
+ model = Language
616
+ paginate_by = 5
617
+ last = bot.uchat.last
618
+
619
+ class BotViewDetail(generic.DetailView):
620
+ model = Language
621
+
622
+ ##@login_required
623
+ ##@permission_required('catalog.can_mark_returned', raise_exception=True)
624
+
templates/.DS_Store ADDED
Binary file (6.15 kB). View file
 
templates/base_generic.html ADDED
@@ -0,0 +1,74 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ <!DOCTYPE html>
2
+ <html lang="en">
3
+ <head>
4
+ {% block title %}<title>UChat</title>{% endblock %}
5
+ <meta charset="utf-8">
6
+ <meta name="viewport" content="width=device-width, initial-scale=1">
7
+ <link href="https://cdn.jsdelivr.net/npm/bootstrap@5.3.2/dist/css/bootstrap.min.css" rel="stylesheet" integrity="sha384-T3c6CoIi6uLrA9TneNEoa7RxnatzjcDSCmG1MXxSR1GAsXEV/Dwwykc2MPK8M2HN" crossorigin="anonymous">
8
+
9
+ <!-- Add additional CSS in static file -->
10
+ {% load static %}
11
+ <link rel="stylesheet" href="{% static 'css/styles.css' %}">
12
+ </head>
13
+ <body>
14
+
15
+ <div class="container-fluid">
16
+
17
+ <div class="row">
18
+ <div class="col-sm-2">
19
+ {% block sidebar %}
20
+ <ul class="sidebar-nav">
21
+ <li><a href="{% url 'index' %}">UChat</a></li>
22
+ <li><a href="{% url 'bot' %}">UChat editor</a></li>
23
+ <li><a href="{% url 'params' %}">Parametri</a></li>
24
+ <li><a href="{% url 'importpdf' %}">Import PDF</li>
25
+ </ul>
26
+
27
+ <ul class="sidebar-nav">
28
+ {% if user.is_authenticated %}
29
+ <li>User: {{ user.get_username }}</li>
30
+ <li><a href="{% url 'admin' %}">Admin</a></li>
31
+ <li><a href="{% url 'logout'%}?next={{request.path}}">Logout</a></li>
32
+ {% else %}
33
+ <li><a href="{% url 'login'%}?next={{request.path}}">Login</a></li>
34
+ {% endif %}
35
+ </ul>
36
+
37
+ {% if user.is_staff %}
38
+ <hr>
39
+ <ul class="sidebar-nav">
40
+ <li>Admin</li>
41
+ {% if True %}
42
+ <li><a href="{% url 'admin' %}">Admin</a></li>
43
+ {% endif %}
44
+ </ul>
45
+ {% endif %}
46
+
47
+ {% endblock %}
48
+ </div>
49
+ <div class="col-sm-10 ">
50
+ {% block content %}{% endblock %}
51
+
52
+ {% block pagination %}
53
+ {% if is_paginated %}
54
+ <div class="pagination">
55
+ <span class="page-links">
56
+ {% if page_obj.has_previous %}
57
+ <a href="{{ request.path }}?page={{ page_obj.previous_page_number }}">previous</a>
58
+ {% endif %}
59
+ <span class="page-current">
60
+ Page {{ page_obj.number }} of {{ page_obj.paginator.num_pages }}.
61
+ </span>
62
+ {% if page_obj.has_next %}
63
+ <a href="{{ request.path }}?page={{ page_obj.next_page_number }}">next</a>
64
+ {% endif %}
65
+ </span>
66
+ </div>
67
+ {% endif %}
68
+ {% endblock %}
69
+ </div>
70
+ </div>
71
+
72
+ </div>
73
+ </body>
74
+ </html>
templates/bot/language_detail.html ADDED
@@ -0,0 +1,16 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ {% extends "base_generic.html" %}
2
+
3
+ {% block content %}
4
+
5
+ <h1>Jezik: {{ language.name }}</h1>
6
+
7
+ <ul>
8
+ <li>
9
+ <p><strong>ID:</strong> {{ language.id}}</p>
10
+ </li>
11
+ <li>
12
+ <p><strong>Skraćeno:</strong> {{ language.lid }}</p>
13
+ </li>
14
+ </ul>
15
+
16
+ {% endblock %}
templates/bot/language_list.html ADDED
@@ -0,0 +1,16 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ {% extends "base_generic.html" %}
2
+
3
+ {% block content %}
4
+
5
+ <h1>Language List</h1>
6
+
7
+ <ul>
8
+ {% for language in language_list %}
9
+ <li>
10
+ <a href="{{ language.get_absolute_url }}">{{ language.name }}</a>
11
+ </li>
12
+ {% empty %}
13
+ <li>There are no languages available.</li>
14
+ {% endfor %}
15
+ </ul>
16
+ {% endblock %}
templates/index.html ADDED
@@ -0,0 +1,41 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+
2
+ {% extends "base_generic.html" %}
3
+
4
+ {% block content %}
5
+
6
+ <script type="text/javascript">
7
+ function status(element) {
8
+ document.getElementById("query").style.display = "hidden"
9
+ element.submit()
10
+ }
11
+ </script>
12
+ <h1>UChat prototip</h1>
13
+
14
+ <p>
15
+ <div style="width:800px;overflow:auto">
16
+ <pre style="white-space:pre-wrap;">
17
+ {{ reply }}
18
+ </pre>
19
+ </p>
20
+ </div>
21
+ <p>
22
+ <form onsubmit="status(this)" action="{% url 'index' %}" method="POST">
23
+ {% csrf_token %}
24
+ <label for="query">Prompt: </label>
25
+ <br>
26
+ <input type="text" id="query" name="query" maxlength="130" size="80" value="" autofocus>
27
+ <br>
28
+ <input type="submit" value="OK">
29
+ <br><br> &nbsp; &nbsp; &nbsp;
30
+ <label for="jezik">Jezik:</label> &nbsp; &nbsp; &nbsp;
31
+ <select id="jezik" name="jezik">
32
+ <option value="hrvatski" {{ selected_hr }}>hrvatski</option>
33
+ <option value="slovenački" {{ selected_sl }}>slovenački</option>
34
+ <option value="srpski" {{ selected_sr }}>srpski</option>
35
+ <option value="makedonski" {{ selected_mk }}>makedonski</option>
36
+ </select>
37
+ </form>
38
+ </p>
39
+
40
+ {% endblock %}
41
+
templates/index_editor.html ADDED
@@ -0,0 +1,76 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ {% extends "base_generic.html" %}
2
+
3
+ {% block content %}
4
+
5
+ <h1>Editor</h1>
6
+ <br>
7
+ <table width="100%">
8
+ <caption>Ukupno: {{ nr }} od {{ last }}</caption>
9
+ <thead>
10
+ <tr>
11
+ <th width="5%">id</th>
12
+ {% if id == "" %}
13
+ <th width="5%">state</th>
14
+ <th width="5%">next</th>
15
+ <th width="5%">page</th>
16
+ <th width="10%">jezik</th>
17
+ <th widht="70%">document</th>
18
+ </tr><tr>
19
+ <form action="{% url "bot"%}" method="POST">
20
+ {% csrf_token %}
21
+ <th><input type="text" maxlength=5" size="5" id="f_id" name="f_id" value="{{ f_id }}"></th>
22
+ <th><input type="text" maxlength=5" size="5" id="f_state" name="f_state" value="{{ f_state }}"></th>
23
+ <th><input type="text" maxlength=5" size="5" id="f_next" name="f_next" value="{{ f_next }}"></th>
24
+ <th><input type="text" maxlength=5" size="5" id="f_page" name="f_page" value="{{ f_page }}"></th>
25
+ <th><input type="text" maxlength=10" size="10" id="f_jezik" name="f_jezik" value="{{ f_jezik }}"></th>
26
+ <th><input type="text" maxlength=64" size="64" id="f_docu" name="f_docu" value="{{ f_docu }}"></th>
27
+ <input type="submit" value="Refresh">
28
+ </form>
29
+ {% endif %}
30
+ </tr>
31
+ </thead>
32
+ <tbody>
33
+ {% if id == "" %}
34
+ {% for row in id_docs %}
35
+ <tr>
36
+ {% for col in row %}
37
+ {% if col|slice:":2" == "id" %}
38
+ <td><a href="{% url 'editor_id' col|slice:"2:" 0 %}">{{ col }}</a></td>
39
+ {% else %}
40
+ <td width="">{{ col|truncatewords:16 }}</td>
41
+ {% endif %}
42
+ {% endfor %}
43
+ </tr>
44
+ {% endfor %}
45
+ {% else %}
46
+ <tr><td>{{ id }}</td><td></td></tr>
47
+ {% endif %}
48
+ </tbody>
49
+ </table>
50
+ <br>
51
+ {% if id != "" %}
52
+ <form action='{% url 'editor_id' id 0 %}' method="POST">
53
+ {% csrf_token %}
54
+ <table>
55
+ <input type="hidden" id="id" name="id" value="id{{ id }}">
56
+ <tr><td><label for="state">state:</label></td><td><input type="text" id="state" name="state" value="{{ state }}"></input></td></tr>
57
+ <tr><td><label for="next">next:</label></td><td><input type="text" id="next" name="next" value="{{ next }}"></input></td></tr>
58
+ <tr><td><label for="page">page:</label></td><td><input type="text" id="page" name="page" value="{{ page }}"></input></td></tr>
59
+ <tr><td><label for="used">used:</label></td><td><input type="text" id="used" name="used" value="{{ used }}"></input></td></tr>
60
+ <tr><td><label for="docu">document:</label></td><td><textarea id="docu" name="docu" cols="80" rows="10">{{ docu }}</textarea></td></tr>
61
+ <tr><td><label for="source">source:</label></td><td><input type="text" id="source" name="source" value="{{ source }}"></input></td></tr>
62
+ <tr><td></td><td> <select id="jezik" name="jezik">
63
+ <option value="hrvatski" {{ selected_hr }}>hrvatski</option>
64
+ <option value="slovenački" {{ selected_sl }}>slovenački</option>
65
+ <option value="srpski" {{ selected_sr }}>srpski</option>
66
+ <option value="makedonski" {{ selected_mk }}>makedonski</option>
67
+ </select></td></tr>
68
+ </table>
69
+ <br>
70
+ <div><input type="submit" value="Update" /></div>
71
+ <div><input type="submit" value="Create" formaction="{% url 'editor_id' id 1 %}" /></div>
72
+ <div><input type="submit" value="Delete" formaction="{% url 'editor_id' id 2 %}" /></div>
73
+ <br>
74
+ </form>
75
+ {% endif %}
76
+ {% endblock %}
templates/index_import.html ADDED
@@ -0,0 +1,29 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+
2
+ {% extends "base_generic.html" %}
3
+
4
+ {% block content %}
5
+
6
+ <h1>PDF import</h1>
7
+ <p/>
8
+ {{ answer }}
9
+ <p/>
10
+ <form action="{% url 'importpdf' %}" method="POST">
11
+ {% csrf_token %}
12
+ <label for="path">Path: </label>
13
+ <br>
14
+ <input type="text" id="path" name="path" maxlength="196" size="80" value="{{ path }}" autofocus>
15
+ <br>
16
+ <input type="submit" value="OK">
17
+ <p/>
18
+ <select id="jezik" name="jezik">
19
+ <option value="hrvatski" {{ selected_hr }}>hrvatski</option>
20
+ <option value="slovenački" {{ selected_sl }}>slovenački</option>
21
+ <option value="srpski" {{ selected_sr }}>srpski</option>
22
+ <option value="makedonski" {{ selected_mk }}>makedonski</option>
23
+ </select>
24
+ <
25
+ </form>
26
+ <p/>
27
+
28
+ {% endblock %}
29
+
templates/index_params.html ADDED
@@ -0,0 +1,107 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+
2
+ {% extends "base_generic.html" %}
3
+
4
+ {% block content %}
5
+
6
+ <script type="text/javascript">
7
+ function status(element) {
8
+ element.style.display = "hidden"
9
+ element.submit()
10
+ }
11
+ </script>
12
+ <h1>UChat prototip</h1>
13
+ <p><p>
14
+ <form onsubmit="status(this); return true;" action="{% url 'params-refresh' %}" method="POST" name="ParamForm" id="ParamForm">
15
+ {% csrf_token %}
16
+ <table border="0">
17
+ <tr><td>
18
+ <label for="CHUNK_SIZE">CHUNK_SIZE: </label></td><td>
19
+ <input type="text" id="CHUNK_SIZE" name="CHUNK_SIZE" maxlength="8" size="8" value="{{ CHUNK_SIZE }}">
20
+ </td></tr>
21
+ <tr><td>
22
+ <label for="CHUNK_OVERLAP">CHUNK_OVERLAP: &nbsp; &nbsp; </label></td><td>
23
+ <input type="text" id="CHUNK_OVERLAP" name="CHUNK_OVERLAP" maxlength="8" size="8" value="{{ CHUNK_OVERLAP }}">
24
+ </td></tr>
25
+ <tr><td>
26
+ <label for="min_distance">min_distance: </label></td><td>
27
+ <input type="text" id="min_distance" name="min_distance" maxlength="8" size="8" value="{{ min_distance }}">
28
+ </ttd></tr>
29
+ <tr><td>
30
+ <label for="max_distance">max_distance: </label></td><td>
31
+ <input type="text" id="max_distance" name="max_distance" maxlength="8" size="8" value="{{ max_distance }}">
32
+ </td></tr>
33
+ <tr><td>
34
+ <label for="max_results">max_results: </label></td><td>
35
+ <input type="text" id="max_results" name="max_results" maxlength="8" size="8" value="{{ max_results }}">
36
+ </td></tr>
37
+ <tr><td>
38
+ <label for="max_conv">max_conv: </label></td><td>
39
+ <input type="text" id="max_conv" name="max_conv" maxlength="8" size="8" value="{{ max_conv }}">
40
+ </td></tr>
41
+ <tr><td>
42
+ <label for="min_len">min_len: </label></td><td>
43
+ <input type="text" id="min_len" name="min_len" maxlength="8" size="8" value="{{ min_len }}">
44
+ </td></tr>
45
+ <tr><td>
46
+ <label for="temperature">temperature: </label></td><td>
47
+ <input type="text" id="temperature" name="temperature" maxlength="8" size="8" value="{{ temperature }}">
48
+ </td></tr>
49
+ <tr><td>
50
+ <label for="top_p">top_p: </label></td><td>
51
+ <input type="text" id="top_p" name="top_p" maxlength="8" size="8" value="{{ top_p }}">
52
+ </td></tr>
53
+ <tr><td>
54
+ <label for="frequency_penalty">frequency_penalty: </label></td><td>
55
+ <input type="text" id="frequency_penalty" name="frequency_penalty" maxlength="8" size="8" value="{{ frequency_penalty }}">
56
+ </td></tr>
57
+ <tr><td>
58
+ <label for="presence_penalty">presence_penalty: </label></td><td>
59
+ <input type="text" id="presence_penalty" name="presence_penalty" maxlength="8" size="8" value="{{ presence_penalty }}">
60
+ </td></tr>
61
+ <tr><td>
62
+ <label for="max_tokens">max_tokens: </label></td><td>
63
+ <input type="text" id="max_tokens" name="max_tokens" maxlength="8" size="8" value="{{ max_tokens }}">
64
+ </td></tr>
65
+ <tr><td>
66
+ <label for="DEBUG">DEBUG: </label></td><td>
67
+ <input type="text" id="DEBUG" name="DEBUG" maxlength="8" size="8" value="{{ DEBUG }}">
68
+ </td></tr>
69
+ <tr><td>
70
+ <label for="ctxpre">ctxpre: </label></td><td>
71
+ <input type="text" id="ctxpre" name="ctxpre" maxlength="8" size="8" value="{{ ctxpre }}">
72
+ </td></tr>
73
+ <tr><td>
74
+ <label for="EMBED_MODEL">EMBED_MODEL: </label></td><td>
75
+ <input type="text" id="EMBED_MODEL" name="EMBED_MODEL" maxlength="80" size="80" value="{{ EMBED_MODEL }}">
76
+ </td></tr>
77
+ <tr><td>
78
+ <label for="model_id">model_id: </label></td><td>
79
+ <input type="text" id="model_id" name="model_id" maxlength="80" size="80" value="{{ model_id }}">
80
+ </td></tr>
81
+ <tr><td>
82
+ <label for="msg_content">msg_content: (*)</label></td><td>
83
+ <input type="text" id="msg_content" name="msg_content" maxlength="80" size="80" value="{{ msg_content }}">
84
+ </td></tr>
85
+ <tr><td colspan="1">
86
+ <label for="system">system: (*) </label><br></td>
87
+ <td>
88
+ <select id="jezik" name="jezik" onchange='this.form.submit();'>
89
+ <option value="hrvatski" {{ selected_hr }}>hrvatski</option>
90
+ <option value="slovenački" {{ selected_sl }}>slovenački</option>
91
+ <option value="srpski" {{ selected_sr }}>srpski</option>
92
+ <option value="makedonski" {{ selected_mk }}>makedonski</option>
93
+ </select>
94
+ &nbsp; &nbsp; (*)
95
+ </td></tr>
96
+ <tr><td></td><td>
97
+ <textarea id="system" name="system" rows="10" cols="80">{{ system }}</textarea>
98
+ </td></tr>
99
+ </table>
100
+ <input type="submit" value="Refresh"> &nbsp; &nbsp; &nbsp; &nbsp;
101
+ <input type="submit" value="Set" formaction="{% url 'params' %}">
102
+ &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;
103
+ <input type="submit" value="Reset" formaction="{% url 'reset' %}">
104
+ </form>
105
+
106
+ {% endblock %}
107
+
templates/registration/logged_out.html ADDED
@@ -0,0 +1,7 @@
 
 
 
 
 
 
 
 
1
+ {% extends "base_generic.html" %}
2
+
3
+ {% block content %}
4
+ <p>Logged out!</p>
5
+
6
+ <a href="{% url 'login'%}">Click here to login again.</a>
7
+ {% endblock %}
templates/registration/login.html ADDED
@@ -0,0 +1,38 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ {% extends "base_generic.html" %}
2
+
3
+ {% block content %}
4
+
5
+ {% if form.errors %}
6
+ <p>Your username and password didn't match. Please try again.</p>
7
+ {% endif %}
8
+
9
+ {% if next %}
10
+ {% if user.is_authenticated %}
11
+ <p>Your account doesn't have access to this page. To proceed,
12
+ please login with an account that has access.</p>
13
+ {% else %}
14
+ <p>Please login to see this page.</p>
15
+ {% endif %}
16
+ {% endif %}
17
+
18
+ <form method="post" action="{% url 'login' %}">
19
+ {% csrf_token %}
20
+ <table>
21
+ <tr>
22
+ <td>{{ form.username.label_tag }}</td>
23
+ <td>{{ form.username }}</td>
24
+ </tr>
25
+ <tr>
26
+ <td>{{ form.password.label_tag }}</td>
27
+ <td>{{ form.password }}</td>
28
+ </tr>
29
+ </table>
30
+
31
+ <input type="submit" value="login">
32
+ <input type="hidden" name="next" value="{{ next }}">
33
+ </form>
34
+
35
+ {# Assumes you setup the password_reset view in your URLconf #}
36
+ <p><a href="{% url 'password_reset' %}">Lost password?</a></p>
37
+
38
+ {% endblock %}