reckoning-machine 0.0.1__tar.gz
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- reckoning_machine-0.0.1/LICENSE +21 -0
- reckoning_machine-0.0.1/MANIFEST.in +1 -0
- reckoning_machine-0.0.1/PKG-INFO +54 -0
- reckoning_machine-0.0.1/README.md +38 -0
- reckoning_machine-0.0.1/pyproject.toml +32 -0
- reckoning_machine-0.0.1/setup.cfg +4 -0
- reckoning_machine-0.0.1/src/reckoning_machine/__init__.py +20 -0
- reckoning_machine-0.0.1/src/reckoning_machine/cli.py +152 -0
- reckoning_machine-0.0.1/src/reckoning_machine/config.py +23 -0
- reckoning_machine-0.0.1/src/reckoning_machine/githf.py +69 -0
- reckoning_machine-0.0.1/src/reckoning_machine/machina.yaml +7 -0
- reckoning_machine-0.0.1/src/reckoning_machine/machine.py +177 -0
- reckoning_machine-0.0.1/src/reckoning_machine/providers/__init__.py +7 -0
- reckoning_machine-0.0.1/src/reckoning_machine/providers/camelids.py +87 -0
- reckoning_machine-0.0.1/src/reckoning_machine/providers/castor_pollux.py +127 -0
- reckoning_machine-0.0.1/src/reckoning_machine/providers/depsek.py +82 -0
- reckoning_machine-0.0.1/src/reckoning_machine/providers/electroid.py +78 -0
- reckoning_machine-0.0.1/src/reckoning_machine/providers/openai.py +82 -0
- reckoning_machine-0.0.1/src/reckoning_machine/providers/qrog.py +82 -0
- reckoning_machine-0.0.1/src/reckoning_machine/providers/strangelove.py +81 -0
- reckoning_machine-0.0.1/src/reckoning_machine/utilities.py +418 -0
- reckoning_machine-0.0.1/src/reckoning_machine.egg-info/PKG-INFO +54 -0
- reckoning_machine-0.0.1/src/reckoning_machine.egg-info/SOURCES.txt +29 -0
- reckoning_machine-0.0.1/src/reckoning_machine.egg-info/dependency_links.txt +1 -0
- reckoning_machine-0.0.1/src/reckoning_machine.egg-info/entry_points.txt +2 -0
- reckoning_machine-0.0.1/src/reckoning_machine.egg-info/requires.txt +1 -0
- reckoning_machine-0.0.1/src/reckoning_machine.egg-info/top_level.txt +1 -0
- reckoning_machine-0.0.1/tests/test_cli.py +20 -0
- reckoning_machine-0.0.1/tests/test_e2e.py +45 -0
- reckoning_machine-0.0.1/tests/test_llm_soup.py +71 -0
- reckoning_machine-0.0.1/tests/test_utilities.py +69 -0
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
MIT License
|
|
2
|
+
|
|
3
|
+
Copyright (c) 2023 Alexander Fedotov
|
|
4
|
+
|
|
5
|
+
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
6
|
+
of this software and associated documentation files (the "Software"), to deal
|
|
7
|
+
in the Software without restriction, including without limitation the rights
|
|
8
|
+
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
9
|
+
copies of the Software, and to permit persons to whom the Software is
|
|
10
|
+
furnished to do so, subject to the following conditions:
|
|
11
|
+
|
|
12
|
+
The above copyright notice and this permission notice shall be included in all
|
|
13
|
+
copies or substantial portions of the Software.
|
|
14
|
+
|
|
15
|
+
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
16
|
+
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
17
|
+
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
18
|
+
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
19
|
+
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
20
|
+
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
21
|
+
SOFTWARE.
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
include src/reckoning_machine/*.yaml
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
Metadata-Version: 2.4
|
|
2
|
+
Name: reckoning-machine
|
|
3
|
+
Version: 0.0.1
|
|
4
|
+
Summary: Reckoning machine.
|
|
5
|
+
Author-email: Machina Ratiocinatrix <machina.ratio@gmail.com>, Alexander Fedotov <alex.fedotov@aol.com>
|
|
6
|
+
Project-URL: Homepage, https://github.com/reckoning-machine/reckoning-machine
|
|
7
|
+
Keywords: reckoning-machine
|
|
8
|
+
Classifier: Programming Language :: Python :: 3
|
|
9
|
+
Classifier: License :: OSI Approved :: MIT License
|
|
10
|
+
Classifier: Operating System :: OS Independent
|
|
11
|
+
Requires-Python: >=3.10
|
|
12
|
+
Description-Content-Type: text/markdown
|
|
13
|
+
License-File: LICENSE
|
|
14
|
+
Requires-Dist: pyyaml==6.0.3
|
|
15
|
+
Dynamic: license-file
|
|
16
|
+
|
|
17
|
+
# Reckoning-Machine
|
|
18
|
+
Reckoning machine.
|
|
19
|
+
|
|
20
|
+
In order to launch it from the command line or as a Python subprocess:
|
|
21
|
+
```bash
|
|
22
|
+
echo "Theodotos-Alexandreus: Reckon the outcome, machine." \
|
|
23
|
+
| uvx reckoning-machine \
|
|
24
|
+
--provider-api-key sk-proj-... \
|
|
25
|
+
--github-token ghp_...
|
|
26
|
+
```
|
|
27
|
+
|
|
28
|
+
Or, with a local pip installation:
|
|
29
|
+
```bash
|
|
30
|
+
pip install reckoning-machine
|
|
31
|
+
```
|
|
32
|
+
Set the environment variables:
|
|
33
|
+
```bash
|
|
34
|
+
export PROVIDER_API_KEY="sk-proj-..."
|
|
35
|
+
export GITHUB_TOKEN="ghp_..."
|
|
36
|
+
```
|
|
37
|
+
Then:
|
|
38
|
+
```bash
|
|
39
|
+
reckoning-machine -a multilogue.txt
|
|
40
|
+
```
|
|
41
|
+
Or:
|
|
42
|
+
```bash
|
|
43
|
+
reckoning-machine multilogue.txt > response.txt
|
|
44
|
+
```
|
|
45
|
+
Or:
|
|
46
|
+
```bash
|
|
47
|
+
reckoning-machine -a multilogue.txt > tmp && echo tmp > multilogue.txt
|
|
48
|
+
```
|
|
49
|
+
|
|
50
|
+
Or use it in your Python code:
|
|
51
|
+
```Python
|
|
52
|
+
# Python
|
|
53
|
+
import reckoning_machine
|
|
54
|
+
```
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
# Reckoning-Machine
|
|
2
|
+
Reckoning machine.
|
|
3
|
+
|
|
4
|
+
In order to launch it from the command line or as a Python subprocess:
|
|
5
|
+
```bash
|
|
6
|
+
echo "Theodotos-Alexandreus: Reckon the outcome, machine." \
|
|
7
|
+
| uvx reckoning-machine \
|
|
8
|
+
--provider-api-key sk-proj-... \
|
|
9
|
+
--github-token ghp_...
|
|
10
|
+
```
|
|
11
|
+
|
|
12
|
+
Or, with a local pip installation:
|
|
13
|
+
```bash
|
|
14
|
+
pip install reckoning-machine
|
|
15
|
+
```
|
|
16
|
+
Set the environment variables:
|
|
17
|
+
```bash
|
|
18
|
+
export PROVIDER_API_KEY="sk-proj-..."
|
|
19
|
+
export GITHUB_TOKEN="ghp_..."
|
|
20
|
+
```
|
|
21
|
+
Then:
|
|
22
|
+
```bash
|
|
23
|
+
reckoning-machine -a multilogue.txt
|
|
24
|
+
```
|
|
25
|
+
Or:
|
|
26
|
+
```bash
|
|
27
|
+
reckoning-machine multilogue.txt > response.txt
|
|
28
|
+
```
|
|
29
|
+
Or:
|
|
30
|
+
```bash
|
|
31
|
+
reckoning-machine -a multilogue.txt > tmp && echo tmp > multilogue.txt
|
|
32
|
+
```
|
|
33
|
+
|
|
34
|
+
Or use it in your Python code:
|
|
35
|
+
```Python
|
|
36
|
+
# Python
|
|
37
|
+
import reckoning_machine
|
|
38
|
+
```
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
[build-system]
|
|
2
|
+
requires = ["setuptools==82.0.1"]
|
|
3
|
+
build-backend = "setuptools.build_meta"
|
|
4
|
+
|
|
5
|
+
[project]
|
|
6
|
+
name = "reckoning-machine"
|
|
7
|
+
version = "0.0.1"
|
|
8
|
+
authors = [
|
|
9
|
+
{name="Machina Ratiocinatrix", email="machina.ratio@gmail.com"},
|
|
10
|
+
{name="Alexander Fedotov", email="alex.fedotov@aol.com"}
|
|
11
|
+
]
|
|
12
|
+
description = "Reckoning machine."
|
|
13
|
+
readme = "README.md"
|
|
14
|
+
requires-python = ">=3.10"
|
|
15
|
+
classifiers=[
|
|
16
|
+
"Programming Language :: Python :: 3",
|
|
17
|
+
"License :: OSI Approved :: MIT License",
|
|
18
|
+
"Operating System :: OS Independent",
|
|
19
|
+
]
|
|
20
|
+
keywords = ["reckoning-machine"]
|
|
21
|
+
dependencies = [
|
|
22
|
+
"pyyaml == 6.0.3"
|
|
23
|
+
]
|
|
24
|
+
|
|
25
|
+
[project.scripts]
|
|
26
|
+
reckoning-machine = "reckoning_machine.cli:run"
|
|
27
|
+
|
|
28
|
+
[project.urls]
|
|
29
|
+
"Homepage" = "https://github.com/reckoning-machine/reckoning-machine"
|
|
30
|
+
|
|
31
|
+
[dependency-groups]
|
|
32
|
+
dev = ["pytest>=8.0.0"]
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
# -*- coding: utf-8 -*-
|
|
2
|
+
# Python
|
|
3
|
+
|
|
4
|
+
"""Copyright (c) Alexander Fedotov.
|
|
5
|
+
This source code is licensed under the license found in the
|
|
6
|
+
LICENSE file in the root directory of this source tree.
|
|
7
|
+
"""
|
|
8
|
+
from .config import Config
|
|
9
|
+
from .machine import machine
|
|
10
|
+
from .githf import fetch_instructions
|
|
11
|
+
from .utilities import (plato_text_to_muj,
|
|
12
|
+
plato_text_to_mpuj,
|
|
13
|
+
llm_soup_to_text,
|
|
14
|
+
new_plato_text)
|
|
15
|
+
|
|
16
|
+
__all__ = [
|
|
17
|
+
'machine',
|
|
18
|
+
'fetch_instructions',
|
|
19
|
+
'Config'
|
|
20
|
+
]
|
|
@@ -0,0 +1,152 @@
|
|
|
1
|
+
# -*- coding: utf-8 -*-
|
|
2
|
+
# Python
|
|
3
|
+
|
|
4
|
+
"""Copyright (c) Alexander Fedotov.
|
|
5
|
+
This source code is licensed under the license found in the
|
|
6
|
+
LICENSE file in the root directory of this source tree.
|
|
7
|
+
"""
|
|
8
|
+
import os
|
|
9
|
+
import sys
|
|
10
|
+
import select
|
|
11
|
+
import fileinput
|
|
12
|
+
import argparse
|
|
13
|
+
import syslog
|
|
14
|
+
from .config import Config
|
|
15
|
+
from .utilities import new_plato_text
|
|
16
|
+
|
|
17
|
+
|
|
18
|
+
def options_and_arguments():
|
|
19
|
+
# Initialize the parser
|
|
20
|
+
parser = argparse.ArgumentParser(
|
|
21
|
+
description="Reckoning-Machine thinks for you about the meanings.",
|
|
22
|
+
epilog="Example: reckoning-machine input_text.txt > output_text.txt"
|
|
23
|
+
# thinking-machine -a multilogue.txt > tmp && mv tmp multilogue.txt
|
|
24
|
+
)
|
|
25
|
+
|
|
26
|
+
# Give the access key and token, or set the environment variables in advance.
|
|
27
|
+
parser.add_argument('-p', '--provider-api-key',
|
|
28
|
+
default=os.getenv('PROVIDER_API_KEY', 'no_key'),
|
|
29
|
+
help="LLM provider API key (defaults to $PROVIDER_API_KEY)")
|
|
30
|
+
parser.add_argument('-g', '--github-token',
|
|
31
|
+
default=os.getenv('GITHUB_TOKEN', 'no_token'),
|
|
32
|
+
help="GitHub API token (defaults to $GITHUB_TOKEN)")
|
|
33
|
+
|
|
34
|
+
parser.add_argument('-a', '--append',
|
|
35
|
+
action='store_true',
|
|
36
|
+
help="Append the utterance to the input.")
|
|
37
|
+
|
|
38
|
+
parser.add_argument('-d', '--debug',
|
|
39
|
+
action='store_true',
|
|
40
|
+
help="Debug flag.")
|
|
41
|
+
|
|
42
|
+
# Add the interactive flag
|
|
43
|
+
# parser.add_argument('-i', '--interactive',
|
|
44
|
+
# action='store_true',
|
|
45
|
+
# help="Enable interactive mode (defaults to False)")
|
|
46
|
+
|
|
47
|
+
# Positional arguments (files)
|
|
48
|
+
# '*' captures zero or more arguments into a list, nargs='+' one or more.
|
|
49
|
+
parser.add_argument('filenames',
|
|
50
|
+
nargs='*',
|
|
51
|
+
help="Zero (when text comes though a pipe) or more files to process.")
|
|
52
|
+
return parser
|
|
53
|
+
|
|
54
|
+
|
|
55
|
+
def run():
|
|
56
|
+
"""
|
|
57
|
+
$ text | reckoning-machine # Accepts text from the pipe
|
|
58
|
+
$ echo "...<text>..." | reckoning-machine #
|
|
59
|
+
|
|
60
|
+
$ reckoning-machine multilogue.txt new_turn.txt # ...or files.
|
|
61
|
+
"""
|
|
62
|
+
|
|
63
|
+
args = options_and_arguments().parse_args()
|
|
64
|
+
|
|
65
|
+
# If no files are provided AND no data is being piped in - exit.
|
|
66
|
+
if not args.filenames:
|
|
67
|
+
# Check if stdin (fd 0) is ready to be read
|
|
68
|
+
readable, _, _ = select.select([sys.stdin], [], [], 0.1)
|
|
69
|
+
if not readable:
|
|
70
|
+
print("Error: No input files or piped text stream.")
|
|
71
|
+
options_and_arguments().print_help()
|
|
72
|
+
sys.exit(1)
|
|
73
|
+
|
|
74
|
+
config = Config()
|
|
75
|
+
|
|
76
|
+
if args.provider_api_key:
|
|
77
|
+
if args.provider_api_key.startswith('sk-'):
|
|
78
|
+
if args.provider_api_key.startswith('sk-proj-'):
|
|
79
|
+
config.provider = 'OpenAI'
|
|
80
|
+
os.environ['OPENAI_API_KEY'] = args.provider_api_key
|
|
81
|
+
elif args.provider_api_key.startswith('sk-ant-'):
|
|
82
|
+
config.provider = 'Anthropic'
|
|
83
|
+
os.environ['ANTHROPIC_API_KEY'] = args.provider_api_key
|
|
84
|
+
else:
|
|
85
|
+
config.provider = 'DepSek'
|
|
86
|
+
os.environ['DEPSEK_API_KEY'] = args.provider_api_key
|
|
87
|
+
elif args.provider_api_key.startswith('AIzaSy'):
|
|
88
|
+
config.provider = 'Gemini'
|
|
89
|
+
os.environ['GEMINI_API_KEY'] = args.provider_api_key
|
|
90
|
+
elif args.provider_api_key.startswith('gsk_'):
|
|
91
|
+
config.provider = 'Groq'
|
|
92
|
+
os.environ['GROQ_API_KEY'] = args.provider_api_key
|
|
93
|
+
elif args.provider_api_key.startswith('xai-'):
|
|
94
|
+
config.provider = 'XAI'
|
|
95
|
+
os.environ['XAI_API_KEY'] = args.provider_api_key
|
|
96
|
+
elif args.provider_api_key.startswith('LLM|'):
|
|
97
|
+
config.provider = 'Meta'
|
|
98
|
+
os.environ['META_API_KEY'] = args.provider_api_key
|
|
99
|
+
elif args.provider_api_key == 'no_provider_key':
|
|
100
|
+
sys.stderr.write(f'No provider key!\n')
|
|
101
|
+
sys.stderr.flush()
|
|
102
|
+
sys.exit(1)
|
|
103
|
+
else:
|
|
104
|
+
if config.provider == '':
|
|
105
|
+
raise ValueError(f"Unrecognized API key prefix and no provider specified.")
|
|
106
|
+
|
|
107
|
+
config.provider_api_key = args.provider_api_key
|
|
108
|
+
|
|
109
|
+
if args.github_token:
|
|
110
|
+
config.github_token = args.github_token
|
|
111
|
+
os.environ['GITHUB_TOKEN'] = args.github_token
|
|
112
|
+
|
|
113
|
+
# Ingest files line by line. Join is here for long files.
|
|
114
|
+
lines = []
|
|
115
|
+
for line in fileinput.input(files=args.filenames or ['-'], encoding="utf-8"):
|
|
116
|
+
lines.append(line)
|
|
117
|
+
raw_input = "".join(lines)
|
|
118
|
+
|
|
119
|
+
from .machine import machine
|
|
120
|
+
|
|
121
|
+
try:
|
|
122
|
+
thoughts, text = machine(raw_input, config)
|
|
123
|
+
output = new_plato_text(thoughts, text, config.name)
|
|
124
|
+
if args.append:
|
|
125
|
+
output = raw_input +'\n\n' + output
|
|
126
|
+
sys.stdout.write(output)
|
|
127
|
+
sys.stdout.flush()
|
|
128
|
+
|
|
129
|
+
# Assesment and signals.
|
|
130
|
+
utterance = "My answer is ready"
|
|
131
|
+
# Open syslog connection
|
|
132
|
+
syslog.openlog(
|
|
133
|
+
ident="reckoning-machine",
|
|
134
|
+
logoption=syslog.LOG_NDELAY,
|
|
135
|
+
facility=syslog.LOG_USER
|
|
136
|
+
)
|
|
137
|
+
# Signal (single line less than 4096 only!)
|
|
138
|
+
syslog.syslog(syslog.LOG_INFO, f"reckoning-machine: {utterance}.")
|
|
139
|
+
syslog.closelog()
|
|
140
|
+
|
|
141
|
+
except Exception as e:
|
|
142
|
+
if args.debug:
|
|
143
|
+
import traceback
|
|
144
|
+
traceback.print_exc()
|
|
145
|
+
else:
|
|
146
|
+
sys.stderr.write(f'Machine did not work {e}\n')
|
|
147
|
+
sys.stderr.flush()
|
|
148
|
+
sys.exit(1)
|
|
149
|
+
|
|
150
|
+
|
|
151
|
+
if __name__ == '__main__':
|
|
152
|
+
run()
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
# -*- coding: utf-8 -*-
|
|
2
|
+
# Python
|
|
3
|
+
|
|
4
|
+
"""Copyright (c) Alexander Fedotov.
|
|
5
|
+
This source code is licensed under the license found in the
|
|
6
|
+
LICENSE file in the root directory of this source tree.
|
|
7
|
+
"""
|
|
8
|
+
from os import environ
|
|
9
|
+
from dataclasses import dataclass, field
|
|
10
|
+
|
|
11
|
+
|
|
12
|
+
@dataclass
|
|
13
|
+
class Config:
|
|
14
|
+
github_token: str = field(default_factory=lambda: environ.get('GITHUB_TOKEN', ''))
|
|
15
|
+
github_name: str = field(default_factory=lambda: environ.get('GITHUB_NAME', ''))
|
|
16
|
+
github_email: str = field(default_factory=lambda: environ.get('GITHUB_EMAIL', ''))
|
|
17
|
+
provider_api_key: str = field(default_factory=lambda: environ.get('PROVIDER_API_KEY', ''))
|
|
18
|
+
provider: str = field(default_factory=lambda: environ.get('PROVIDER', ''))
|
|
19
|
+
machine_organization_name: str = field(default_factory=lambda: environ.get('MACHINE_ORGANIZATION_NAME', 'reckoning-machine'))
|
|
20
|
+
private_repo_with_text: str = field(default_factory=lambda: environ.get('PRIVATE_REPO_WITH_TEXT','reckoning_machine'))
|
|
21
|
+
system_prompt_file: str = field(default_factory=lambda: environ.get('SYSTEM_PROMPT_FILE', 'machina.yaml'))
|
|
22
|
+
name: str = ''
|
|
23
|
+
instructions: str = ''
|
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
# -*- coding: utf-8 -*-
|
|
2
|
+
# Python
|
|
3
|
+
|
|
4
|
+
"""Copyright (c) Alexander Fedotov.
|
|
5
|
+
This source code is licensed under the license found in the
|
|
6
|
+
LICENSE file in the root directory of this source tree.
|
|
7
|
+
"""
|
|
8
|
+
import sys
|
|
9
|
+
from os import path
|
|
10
|
+
import yaml
|
|
11
|
+
import urllib.request
|
|
12
|
+
import urllib.error
|
|
13
|
+
|
|
14
|
+
|
|
15
|
+
def download_github_file(owner, repo, file_path, token):
|
|
16
|
+
"""
|
|
17
|
+
Downloads a file from a GitHub repository using the GitHub REST API.
|
|
18
|
+
We request the raw content by using the 'application/vnd.github.v3.raw' accept header.
|
|
19
|
+
"""
|
|
20
|
+
url = f"https://api.github.com/repos/{owner}/{repo}/contents/{file_path}"
|
|
21
|
+
|
|
22
|
+
headers = {
|
|
23
|
+
"Authorization": f"token {token}",
|
|
24
|
+
"Accept": "application/vnd.github.v3.raw",
|
|
25
|
+
"User-Agent": "Reckoning-Machine"
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
req = urllib.request.Request(url, headers=headers)
|
|
29
|
+
|
|
30
|
+
try:
|
|
31
|
+
with urllib.request.urlopen(req, timeout=10) as response:
|
|
32
|
+
return response.read()
|
|
33
|
+
except urllib.error.HTTPError as e:
|
|
34
|
+
print(f"HTTP Error {e.code}: {e.reason}")
|
|
35
|
+
error_info = e.read().decode('utf-8')
|
|
36
|
+
print(f"Details: {error_info}")
|
|
37
|
+
return None
|
|
38
|
+
except urllib.error.URLError as e:
|
|
39
|
+
print(f"URL Error: {e.reason}")
|
|
40
|
+
return None
|
|
41
|
+
|
|
42
|
+
|
|
43
|
+
def fetch_instructions(config):
|
|
44
|
+
"""Retrieve the system prompt from a private GitHub repo.
|
|
45
|
+
Falls back to the local machina.yaml if GitHub is unreachable.
|
|
46
|
+
Returns the 'name' of the Machine in dashed format.
|
|
47
|
+
Returns the 'description' field from the YAML as the system prompt string.
|
|
48
|
+
"""
|
|
49
|
+
try:
|
|
50
|
+
raw_yaml = download_github_file(
|
|
51
|
+
owner=config.machine_organization_name,
|
|
52
|
+
repo=config.private_repo_with_text,
|
|
53
|
+
file_path=config.system_prompt_file,
|
|
54
|
+
token=config.github_token
|
|
55
|
+
)
|
|
56
|
+
except Exception as e:
|
|
57
|
+
print(f"Warning: could not fetch the instructions from GitHub: {e}",
|
|
58
|
+
file=sys.stderr)
|
|
59
|
+
local_path = path.join(path.dirname(__file__), 'machina.yaml')
|
|
60
|
+
with open(local_path, 'r') as f:
|
|
61
|
+
raw_yaml = f.read()
|
|
62
|
+
|
|
63
|
+
# Parse
|
|
64
|
+
parsed = yaml.safe_load(raw_yaml)
|
|
65
|
+
name = parsed.get('name')
|
|
66
|
+
config.name = name
|
|
67
|
+
instructions = parsed.get('description', 'You are a helpful assistant.')
|
|
68
|
+
config.instructions = instructions
|
|
69
|
+
return name, instructions
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
# Copyright (c) Alexander Fedotov, 2026. All rights reserved.
|
|
2
|
+
name: Reckoning-Machine
|
|
3
|
+
description: The Assistant is Reckoning-Machine. Reckoning-Machine does its best to understand
|
|
4
|
+
the conversation that it is participating in and answers in a most thoughtful way possible
|
|
5
|
+
the questions that it is being asked.
|
|
6
|
+
Reckoning-Machine responds in plain text without any markdown, emphasis or lists. All
|
|
7
|
+
paragraphs except the first should begin with a newline and tab.
|
|
@@ -0,0 +1,177 @@
|
|
|
1
|
+
# -*- coding: utf-8 -*-
|
|
2
|
+
# Python
|
|
3
|
+
|
|
4
|
+
"""Copyright (c) Alexander Fedotov.
|
|
5
|
+
This source code is licensed under the license found in the
|
|
6
|
+
LICENSE file in the root directory of this source tree.
|
|
7
|
+
"""
|
|
8
|
+
import sys
|
|
9
|
+
from os import environ, path
|
|
10
|
+
from .githf import fetch_instructions
|
|
11
|
+
from .utilities import (plato_text_to_muj,
|
|
12
|
+
plato_text_to_mpuj,
|
|
13
|
+
plato_text_to_cmj,
|
|
14
|
+
llm_soup_to_text)
|
|
15
|
+
|
|
16
|
+
|
|
17
|
+
def machine(plato_text, config, **kwargs):
|
|
18
|
+
"""Core agent logic.
|
|
19
|
+
|
|
20
|
+
1. Fetches the system prompt from a private GitHub repo.
|
|
21
|
+
2. Calls Provider
|
|
22
|
+
3. Returns a (thoughts, text) tuple.
|
|
23
|
+
"""
|
|
24
|
+
# Fetch the confidential system prompt, name is for a checkup.
|
|
25
|
+
name, system_prompt = fetch_instructions(config)
|
|
26
|
+
|
|
27
|
+
# Load an appropriate library and query the API.
|
|
28
|
+
provider = config.provider
|
|
29
|
+
api_key = config.provider_api_key
|
|
30
|
+
|
|
31
|
+
if provider == 'OpenAI':
|
|
32
|
+
# Transform plato_text to MUJ format
|
|
33
|
+
messages = plato_text_to_muj(plato_text=plato_text,
|
|
34
|
+
machine_name=name)
|
|
35
|
+
# Call OpenAI API via opehaina
|
|
36
|
+
environ['OPENAI_API_KEY'] = api_key
|
|
37
|
+
try:
|
|
38
|
+
from .providers import openai
|
|
39
|
+
except ImportError:
|
|
40
|
+
print("openai module is missing.", file=sys.stderr)
|
|
41
|
+
sys.exit(1)
|
|
42
|
+
|
|
43
|
+
thoughts, text = openai.respond(
|
|
44
|
+
messages=messages,
|
|
45
|
+
instructions=system_prompt,
|
|
46
|
+
**kwargs
|
|
47
|
+
)
|
|
48
|
+
|
|
49
|
+
thoughts = llm_soup_to_text(thoughts)
|
|
50
|
+
return thoughts, text
|
|
51
|
+
|
|
52
|
+
elif provider == 'Gemini':
|
|
53
|
+
# Transform plato_text to MPUJ format
|
|
54
|
+
messages = plato_text_to_mpuj(plato_text=plato_text,
|
|
55
|
+
machine_name=name)
|
|
56
|
+
# Call Gemini through castor-polux
|
|
57
|
+
environ['GEMINI_API_KEY'] = api_key
|
|
58
|
+
try:
|
|
59
|
+
from .providers import castor_pollux
|
|
60
|
+
except ImportError:
|
|
61
|
+
print("No module castor-pollux", file=sys.stderr)
|
|
62
|
+
sys.exit(1)
|
|
63
|
+
|
|
64
|
+
thoughts, text = castor_pollux.respond(
|
|
65
|
+
messages=messages,
|
|
66
|
+
instructions=system_prompt,
|
|
67
|
+
**kwargs
|
|
68
|
+
)
|
|
69
|
+
|
|
70
|
+
thoughts = llm_soup_to_text(thoughts)
|
|
71
|
+
return thoughts, text
|
|
72
|
+
|
|
73
|
+
elif provider == 'Anthropic':
|
|
74
|
+
# Transform plato_text to MUJ format
|
|
75
|
+
messages = plato_text_to_muj(plato_text=plato_text,
|
|
76
|
+
machine_name=name)
|
|
77
|
+
|
|
78
|
+
# Call the Anthropic API via electroid
|
|
79
|
+
environ['ANTHROPIC_API_KEY'] = api_key
|
|
80
|
+
try:
|
|
81
|
+
from .providers import electroid
|
|
82
|
+
except ImportError:
|
|
83
|
+
print("no electroid module", file=sys.stderr)
|
|
84
|
+
sys.exit(1)
|
|
85
|
+
|
|
86
|
+
text, thoughts = electroid.respond(
|
|
87
|
+
messages=messages,
|
|
88
|
+
instructions=system_prompt,
|
|
89
|
+
**kwargs
|
|
90
|
+
)
|
|
91
|
+
return text, thoughts
|
|
92
|
+
|
|
93
|
+
elif provider == 'Groq':
|
|
94
|
+
# Transform plato_text to MUJ format
|
|
95
|
+
messages = plato_text_to_muj(plato_text=plato_text,
|
|
96
|
+
machine_name=name)
|
|
97
|
+
# Call OpenAI API via opehaina
|
|
98
|
+
environ['GROQ_API_KEY'] = api_key
|
|
99
|
+
try:
|
|
100
|
+
from .providers import qrog
|
|
101
|
+
except ImportError:
|
|
102
|
+
print("openai module is missing.", file=sys.stderr)
|
|
103
|
+
sys.exit(1)
|
|
104
|
+
|
|
105
|
+
thoughts, text = qrog.respond(
|
|
106
|
+
messages=messages,
|
|
107
|
+
instructions=system_prompt,
|
|
108
|
+
**kwargs
|
|
109
|
+
)
|
|
110
|
+
|
|
111
|
+
thoughts = llm_soup_to_text(thoughts)
|
|
112
|
+
return thoughts, text
|
|
113
|
+
|
|
114
|
+
elif provider == 'Xai':
|
|
115
|
+
# Transform plato_text to MUJ format
|
|
116
|
+
messages = plato_text_to_muj(plato_text=plato_text,
|
|
117
|
+
machine_name=name)
|
|
118
|
+
# Call OpenAI API via opehaina
|
|
119
|
+
environ['XAI_API_KEY'] = api_key
|
|
120
|
+
try:
|
|
121
|
+
from .providers import strangelove
|
|
122
|
+
except ImportError:
|
|
123
|
+
print("openai module is missing.", file=sys.stderr)
|
|
124
|
+
sys.exit(1)
|
|
125
|
+
|
|
126
|
+
thoughts, text = strangelove.respond(
|
|
127
|
+
messages=messages,
|
|
128
|
+
instructions=system_prompt,
|
|
129
|
+
**kwargs
|
|
130
|
+
)
|
|
131
|
+
|
|
132
|
+
thoughts = llm_soup_to_text(thoughts)
|
|
133
|
+
return thoughts, text
|
|
134
|
+
|
|
135
|
+
elif provider == 'DepSek':
|
|
136
|
+
# Transform plato_text to CMJ format
|
|
137
|
+
messages = plato_text_to_cmj(plato_text=plato_text,
|
|
138
|
+
machine_name=name)
|
|
139
|
+
# Call OpenAI API via opehaina
|
|
140
|
+
environ['DEPSEK_API_KEY'] = api_key
|
|
141
|
+
try:
|
|
142
|
+
from .providers import depsek
|
|
143
|
+
except ImportError:
|
|
144
|
+
print("openai module is missing.", file=sys.stderr)
|
|
145
|
+
sys.exit(1)
|
|
146
|
+
|
|
147
|
+
thoughts, text = depsek.respond(
|
|
148
|
+
messages=messages,
|
|
149
|
+
instructions=system_prompt,
|
|
150
|
+
**kwargs
|
|
151
|
+
)
|
|
152
|
+
|
|
153
|
+
return thoughts, text
|
|
154
|
+
|
|
155
|
+
elif provider == 'Meta':
|
|
156
|
+
# Transform plato_text to CMJ format
|
|
157
|
+
messages = plato_text_to_cmj(plato_text=plato_text,
|
|
158
|
+
machine_name=name)
|
|
159
|
+
# Call OpenAI API via opehaina
|
|
160
|
+
environ['META_API_KEY'] = api_key
|
|
161
|
+
try:
|
|
162
|
+
from .providers import camelids
|
|
163
|
+
except ImportError:
|
|
164
|
+
print("openai module is missing.", file=sys.stderr)
|
|
165
|
+
sys.exit(1)
|
|
166
|
+
|
|
167
|
+
thoughts, text = camelids.respond(
|
|
168
|
+
messages=messages,
|
|
169
|
+
instructions=system_prompt,
|
|
170
|
+
**kwargs
|
|
171
|
+
)
|
|
172
|
+
|
|
173
|
+
return thoughts, text
|
|
174
|
+
|
|
175
|
+
|
|
176
|
+
if __name__ == '__main__':
|
|
177
|
+
print('You have launched main')
|