Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Dev Release to Main #2665

Merged
merged 155 commits into from
Feb 13, 2024
Merged
Show file tree
Hide file tree
Changes from 143 commits
Commits
Show all changes
155 commits
Select commit Hold shift + click to select a range
f9ad429
Add endpoint to get repo by ID
Seltyk Aug 7, 2023
a83fee5
It would maybe help if I spelled "schema" right
Seltyk Aug 8, 2023
577c4f8
Pretend the schema is an array for rendering
Seltyk Aug 8, 2023
6101789
Bump tornado from 6.1 to 6.3.3
dependabot[bot] Oct 30, 2023
cf8bf5b
Bump joblib in /augur/tasks/data_analysis/message_insights
dependabot[bot] Nov 1, 2023
08e7a31
Bump scipy in /augur/tasks/data_analysis/discourse_analysis
dependabot[bot] Nov 1, 2023
cb7c632
Bump scipy in /augur/tasks/data_analysis/pull_request_analysis_worker
dependabot[bot] Nov 1, 2023
b819f4d
Bump scipy from 1.7.3 to 1.10.0
dependabot[bot] Nov 1, 2023
dc3468b
Bump scipy in /augur/tasks/data_analysis/message_insights
dependabot[bot] Nov 1, 2023
8e36b39
Work on adding ORM syntax into RLC
Ulincsys Nov 1, 2023
eb42254
Merge pull request #2571 from chaoss/dependabot/pip/augur/tasks/data_…
sgoggins Nov 2, 2023
d94543d
Merge pull request #2570 from chaoss/dependabot/pip/scipy-1.10.0
sgoggins Nov 2, 2023
415a433
Merge pull request #2569 from chaoss/dependabot/pip/augur/tasks/data_…
sgoggins Nov 2, 2023
a3f7bbd
Merge pull request #2568 from chaoss/dependabot/pip/augur/tasks/data_…
sgoggins Nov 2, 2023
1f987ed
Merge pull request #2566 from chaoss/dependabot/pip/tornado-6.3.3
sgoggins Nov 2, 2023
ce17876
Merge pull request #2565 from chaoss/dependabot/pip/augur/tasks/data_…
sgoggins Nov 2, 2023
c21c8b3
updating joblib version requirement in pr analysis
sgoggins Nov 2, 2023
9e023b1
Update repo_load_controller.py to use orm syntax.
ABrain7710 Nov 3, 2023
631aea2
Fix orm warnings
ABrain7710 Nov 4, 2023
1423393
Merge pull request #2581 from chaoss/fix-warnings
sgoggins Nov 4, 2023
6531b9a
Merge pull request #2580 from chaoss/repo-load-controller-parity
sgoggins Nov 4, 2023
3a5bd3d
Merge pull request #2582 from chaoss/dev
sgoggins Nov 4, 2023
de5a69f
Fix issue when merging branches together
ABrain7710 Nov 4, 2023
0799f8e
Merge pull request #2583 from chaoss/merge-fix
sgoggins Nov 4, 2023
23335d0
Merge pull request #2584 from chaoss/dev
sgoggins Nov 4, 2023
abd3935
Merge pull request #2579 from chaoss/dev-dependabot
sgoggins Nov 20, 2023
d18baa3
Start renaming things to be github specific and adding gitlab functions
ABrain7710 Nov 28, 2023
2b25d59
Continue changing code to insert gitlab repos
ABrain7710 Nov 28, 2023
ca77029
Update gitlab api key handler and gitlab random key auth to use gitlab
ABrain7710 Nov 28, 2023
63b6350
Change is_valid_gitlab_repo to use gitlab api
ABrain7710 Nov 28, 2023
8446c04
Clean up method
ABrain7710 Nov 28, 2023
9a0fb08
Renaming
ABrain7710 Nov 28, 2023
dccb8bc
Fix insert logic to work for gitlab
ABrain7710 Nov 28, 2023
ec0cfff
Successfully insert gitlab repo
ABrain7710 Nov 29, 2023
291feae
Ensure that gitlab repos aren't being started
ABrain7710 Nov 29, 2023
ccb0df7
Merge pull request #2590 from chaoss/gitlab-changes
sgoggins Nov 29, 2023
12a204a
typing-extensions has to be 4.7.1 for two other packages
sgoggins Nov 29, 2023
3c24954
tensorflow update
sgoggins Nov 29, 2023
59486fe
scipy numpy updates
sgoggins Nov 29, 2023
82c1a1b
numpy
sgoggins Nov 29, 2023
8d4c1d7
keras
sgoggins Nov 29, 2023
d204673
allowing matplotlib to go higher if compatible.
sgoggins Nov 30, 2023
e4d1375
Finished compatibility updates for compilation on osx with python 3.11
sgoggins Nov 30, 2023
574885e
version bump
sgoggins Nov 30, 2023
a5d6522
Update github words to gitlab
ABrain7710 Nov 30, 2023
57ea05f
Merge pull request #2657 from chaoss/deps-update-33
sgoggins Nov 30, 2023
33be983
Basic retrieval of merge requests
ABrain7710 Dec 1, 2023
31b7614
Start gitlab issues collection
ABrain7710 Dec 1, 2023
3a2a46d
Add missed files
ABrain7710 Dec 1, 2023
2d4d149
Add gitlab issue collection'
ABrain7710 Dec 1, 2023
4e104c5
Comment out github error handling logic from gitlab paginator
ABrain7710 Dec 1, 2023
9729bce
Remove commented code
ABrain7710 Dec 1, 2023
f10fb29
fix up imports
ABrain7710 Dec 1, 2023
979e501
Merge pull request #2658 from chaoss/gitlab-changes
sgoggins Dec 4, 2023
20bd29d
Implement gitlab issues labels and assignees
ABrain7710 Dec 4, 2023
0dfcf9b
comment out variable reassignment overriding pr_issue_count
IsaacMilarky Dec 4, 2023
11340d4
Missed in last commit
ABrain7710 Dec 4, 2023
286aa0c
Update firefox version to match requirement of firefox-geckodriver
oleks Dec 5, 2023
1a187bc
Merge pull request #2659 from chaoss/pr-issue-count-fix
sgoggins Dec 5, 2023
9f635ba
MerZge branch 'dev' into gitlab-changes
ABrain7710 Dec 6, 2023
de4217e
Fix small bugs in assignees and labels for mrs
ABrain7710 Dec 8, 2023
924a7ad
Setup passing of mr ids to next tasks
ABrain7710 Dec 8, 2023
5a80cf2
Setup issues tasks to pass ids to next tasks
ABrain7710 Dec 8, 2023
57ce5de
Add collection of gitlab events & comments
ABrain7710 Dec 8, 2023
ca6544d
Setup urls for merge request collections
ABrain7710 Dec 8, 2023
daa4106
Refeactor gitlab paginator
ABrain7710 Dec 9, 2023
4d5b4b2
Add collection for all the mr data
ABrain7710 Dec 9, 2023
9793d44
Add merge request events collection
ABrain7710 Dec 9, 2023
29c31d5
Add gitlab event data mappers
ABrain7710 Dec 9, 2023
0d0efb4
Add issue event db inserts
ABrain7710 Dec 9, 2023
0e1dde5
Add mr event processing
ABrain7710 Dec 9, 2023
dbe280a
Start on mr reviewers
ABrain7710 Dec 9, 2023
b1a2ea6
Add start of mr reviewer processing
ABrain7710 Dec 9, 2023
a7c3195
Add processing for mr commits
ABrain7710 Dec 9, 2023
1ca0855
Add processing for mr files
ABrain7710 Dec 9, 2023
b45db1e
Add processing for mr metadata
ABrain7710 Dec 9, 2023
f43a9fd
Add processing for issues messages
ABrain7710 Dec 9, 2023
3c096d7
Add processing for mr messages
ABrain7710 Dec 9, 2023
99e94c9
Comment out assignee inserts and update tasks that are running
ABrain7710 Dec 9, 2023
a023408
comment out message collection
ABrain7710 Dec 9, 2023
ba24d20
Remove logic that stopped the collection early
ABrain7710 Dec 9, 2023
13eb449
Fix small bugs
ABrain7710 Dec 9, 2023
05b53ec
Fix bug in gitlab api handler
ABrain7710 Dec 9, 2023
ac3a815
Merge pull request #2661 from chaoss/gitlab-changes
sgoggins Dec 19, 2023
cce213a
Merge pull request #2660 from oleks/main
sgoggins Jan 2, 2024
90add5e
updated readme with public instance link
sgoggins Jan 2, 2024
f31308a
Fix collection issue
ABrain7710 Jan 12, 2024
84b1a01
Merge pull request #2664 from chaoss/fix-collection-issue
sgoggins Jan 12, 2024
7370873
Fix syntax error in json parsing method
ABrain7710 Jan 13, 2024
f9717c9
Update metadata.py
sgoggins Jan 17, 2024
db449ca
Update README.md
sgoggins Jan 17, 2024
ad0985a
Update Dockerfile
sgoggins Jan 17, 2024
0a43a50
Update Dockerfile
sgoggins Jan 17, 2024
6164e1c
add GitHub workflow to run linting checks, namely Pylint for now
IsaacMilarky Jan 17, 2024
eaeb4e9
also add misspell check
IsaacMilarky Jan 17, 2024
562450e
Merge pull request #2476 from Seltyk/repo-by-id
IsaacMilarky Jan 17, 2024
d723825
Merge branch 'dev' into use-pylint-checks
IsaacMilarky Jan 17, 2024
e3e9a61
Merge pull request #2666 from chaoss/use-pylint-checks
sgoggins Jan 18, 2024
ae75bef
Fix null string in releases insert
ABrain7710 Jan 20, 2024
80d0c9d
Fix messages NoneType error
ABrain7710 Jan 20, 2024
c2d97ab
Fix issue where table isn't passed into recursive call
ABrain7710 Jan 23, 2024
1c94076
Merge pull request #2667 from chaoss/fix-collection-issue
ABrain7710 Jan 23, 2024
9e7cc37
Merge branch 'dev' into fix-insert-data-issue
ABrain7710 Jan 23, 2024
ef169be
Add 5 second delay before we retry
ABrain7710 Jan 23, 2024
888dd23
Change to 3 second delay
ABrain7710 Jan 23, 2024
eb3887f
Fix issues suggested by linter
ABrain7710 Jan 23, 2024
51c58e6
Fix other issues suggested by linter
ABrain7710 Jan 23, 2024
ce50ea3
Merge pull request #2668 from chaoss/fix-insert-data-issue
sgoggins Jan 23, 2024
c770c36
Update Dockerfile
sgoggins Jan 23, 2024
25ebabb
Update Dockerfile
sgoggins Jan 23, 2024
9ab76e7
address linting errors in data_parse.py
IsaacMilarky Jan 23, 2024
b166fd6
fix typos and add module doc-strings
IsaacMilarky Jan 23, 2024
29247b9
Update setup.py
sgoggins Jan 23, 2024
3aec047
Update setup.py
sgoggins Jan 23, 2024
fbcc02d
Update setup.py
sgoggins Jan 23, 2024
7057675
Update setup.py
sgoggins Jan 23, 2024
8ba2195
Update setup.py
sgoggins Jan 23, 2024
251e534
Update Dockerfile
sgoggins Jan 23, 2024
d03dca7
Update Dockerfile
sgoggins Jan 23, 2024
7f205db
add docs to pull_requests/tasks.py
IsaacMilarky Jan 23, 2024
9273baa
apply linting to events_task.py for gitlab methods
IsaacMilarky Jan 23, 2024
4cbfa15
unneeded elif
IsaacMilarky Jan 23, 2024
fc3d13b
add doc-strings to gitlab tasks and data structures
IsaacMilarky Jan 23, 2024
579dec0
remove unused variable
IsaacMilarky Jan 23, 2024
59afa43
use vars
IsaacMilarky Jan 23, 2024
bd80a0e
Merge pull request #2669 from chaoss/isaac-fix-pylint-errs
sgoggins Jan 24, 2024
91b84a8
Update Dockerfile
sgoggins Jan 26, 2024
2b242ef
Update Dockerfile
sgoggins Jan 26, 2024
5da3277
Update Dockerfile
sgoggins Jan 26, 2024
3e79270
Update Dockerfile
sgoggins Jan 26, 2024
21b5dd6
Update Dockerfile
sgoggins Jan 26, 2024
b61480b
Update Dockerfile
sgoggins Jan 26, 2024
79d74a1
Update Dockerfile
sgoggins Jan 26, 2024
3a1d89a
Update Dockerfile
sgoggins Jan 26, 2024
41ad59d
Update Dockerfile
sgoggins Jan 26, 2024
8fcc429
Update spec.yml
sgoggins Jan 26, 2024
5099e31
Fixing PyLint Error
sgoggins Jan 26, 2024
f6f4f46
Update gitlab_api_handler.py
sgoggins Jan 26, 2024
7433028
Update gitlab_api_handler.py
sgoggins Jan 26, 2024
99ae0f3
Update merge_request_task.py
sgoggins Jan 26, 2024
205d0a3
Update merge_request_task.py
sgoggins Jan 26, 2024
3153f15
readthedocs.io error fix
sgoggins Jan 26, 2024
419f69a
Relaxing mistune version requirements to let pip resolve the correct …
sgoggins Jan 26, 2024
5e86c55
Merge pull request #2670 from chaoss/dev
sgoggins Jan 26, 2024
54c2086
Updated materialized views to include the right logic.
sgoggins Jan 26, 2024
3667942
updated file name
sgoggins Jan 29, 2024
9ad969b
Fix complexity routes
ABrain7710 Jan 30, 2024
7302877
Merge pull request #2671 from chaoss/fix-api-endpoints
sgoggins Jan 30, 2024
6224cfc
Merge pull request #2673 from chaoss/dev
sgoggins Jan 30, 2024
b8b2e94
add volume support, patch python dockerfile dependencies
Feb 6, 2024
f3f7fbe
fixing flower time synchronization issue
sgoggins Feb 8, 2024
f46ee05
adding conn = op.get_bind()
Feb 8, 2024
dab348c
Merge branch 'dev' into main
sgoggins Feb 12, 2024
ea6d2d5
Merge pull request #2677 from GaryPWhite/main
sgoggins Feb 12, 2024
335864c
Merge pull request #2679 from chaoss/mat-view-path-23
sgoggins Feb 12, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
31 changes: 31 additions & 0 deletions .github/workflows/checks.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,31 @@
name: "run-linting-checks"
on:
pull_request:
branches: [main, dev]

jobs:
run-pylint:
name: runner / pylint
permissions: write-all
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v2
- uses: dciborow/[email protected]
with:
github_token: ${{ secrets.GITHUB_TOKEN }}
reporter: github-pr-review
level: warning
glob_pattern: "**/*.py"
filter_mode: "file"

misspell:
name: runner / misspell
runs-on: ubuntu-latest
steps:
- name: Highlight any misspellings in changes.
uses: actions/checkout@v4
- name: misspell
uses: reviewdog/action-misspell@v1
with:
github_token: ${{ secrets.GITHUB_TOKEN }}
locale: "US"
2 changes: 1 addition & 1 deletion .pylintrc
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,7 @@
#refactoring checker
#enable=R

disable=E0611,E1101,W1203,R0801,W0614,W0611,C0411,C0103,C0301,C0303,C0304,C0305,W0311
disable=E0611,E1101,W1203,R0801,W0614,W0611,C0411,C0103,C0301,C0303,C0304,C0305,W0311,E0401


# Analyse import fallback blocks. This can be used to support both Python 2 and
Expand Down
6 changes: 4 additions & 2 deletions README.md
Original file line number Diff line number Diff line change
@@ -1,4 +1,6 @@
# Augur NEW Release v0.60.2
# Augur NEW Release v0.62.0

CHECK out Augur's Public Instance at https://ai.chaoss.io

[![first-timers-only](https://img.shields.io/badge/first--timers--only-friendly-blue.svg?style=flat-square)](https://www.firsttimersonly.com/) We follow the [First Timers Only](https://www.firsttimersonly.com/) philosophy of tagging issues for first timers only, and walking one newcomer through the resolution process weekly. [You can find these issues tagged with "first timers only" on our issues list.](https://github.com/chaoss/augur/labels/first-timers-only).

Expand All @@ -7,7 +9,7 @@
## NEW RELEASE ALERT!
### [If you want to jump right in, updated docker build/compose and bare metal installation instructions are available here](docs/new-install.md)

Augur is now releasing a dramatically improved new version to the main branch. It is also available here: https://github.com/chaoss/augur/releases/tag/v0.60.2
Augur is now releasing a dramatically improved new version to the main branch. It is also available here: https://github.com/chaoss/augur/releases/tag/v0.62.0
- The `main` branch is a stable version of our new architecture, which features:
- Dramatic improvement in the speed of large scale data collection (100,000+ repos). All data is obtained for 100k+ repos within 2 weeks.
- A new job management architecture that uses Celery and Redis to manage queues, and enables users to run a Flower job monitoring dashboard
Expand Down
2 changes: 1 addition & 1 deletion augur/api/routes/dei.py
Original file line number Diff line number Diff line change
Expand Up @@ -52,7 +52,7 @@ def dei_track_repo(application: ClientApplication):
return jsonify({"status": "Repo already exists"})

frontend_repo_group: RepoGroup = session.query(RepoGroup).filter(RepoGroup.rg_name == FRONTEND_REPO_GROUP_NAME).first()
repo_id = Repo.insert(session, repo_url, frontend_repo_group.repo_group_id, "API.DEI", repo_type="")
repo_id = Repo.insert_github_repo(session, repo_url, frontend_repo_group.repo_group_id, "API.DEI", repo_type="")
if not repo_id:
return jsonify({"status": "Error adding repo"})

Expand Down
4 changes: 2 additions & 2 deletions augur/api/routes/user.py
Original file line number Diff line number Diff line change
Expand Up @@ -227,7 +227,7 @@ def add_user_repo():
repo = request.args.get("repo_url")
group_name = request.args.get("group_name")

result = current_user.add_repo(group_name, repo)
result = current_user.add_github_repo(group_name, repo)

return jsonify(result[1])

Expand Down Expand Up @@ -260,7 +260,7 @@ def add_user_org():
org = request.args.get("org_url")
group_name = request.args.get("group_name")

result = current_user.add_org(group_name, org)
result = current_user.add_github_org(group_name, org)

return jsonify(result[1])

Expand Down
62 changes: 51 additions & 11 deletions augur/api/routes/util.py
Original file line number Diff line number Diff line change
@@ -1,21 +1,18 @@
#SPDX-License-Identifier: MIT
from augur.api.routes import AUGUR_API_VERSION
from ..server import app, engine
import base64
import sqlalchemy as s
import pandas as pd
import json
from flask import Response
import logging

from augur.application.db.session import DatabaseSession
from augur.application.logs import AugurLogger
from augur.application.config import AugurConfig

logger = AugurLogger("augur").get_logger()

from augur.api.routes import AUGUR_API_VERSION
from ..server import app, engine


@app.route('/{}/repo-groups'.format(AUGUR_API_VERSION))
def get_all_repo_groups(): #TODO: make this name automatic - wrapper?
repoGroupsSQL = s.sql.text("""
Expand Down Expand Up @@ -54,9 +51,9 @@ def get_all_repos():
(select * from api_get_all_repos_issues) b
on
repo.repo_id = b.repo_id
left outer join
(select * from api_get_all_repo_prs) c
on repo.repo_id=c.repo_id
left outer join
(select * from api_get_all_repo_prs) c
on repo.repo_id=c.repo_id
JOIN repo_groups ON repo_groups.repo_group_id = repo.repo_group_id
order by repo_name
""")
Expand Down Expand Up @@ -95,9 +92,9 @@ def get_repos_in_repo_group(repo_group_id):
(select * from api_get_all_repos_issues) b
on
repo.repo_id = b.repo_id
left outer join
(select * from api_get_all_repo_prs) c
on repo.repo_id=c.repo_id
left outer join
(select * from api_get_all_repo_prs) c
on repo.repo_id=c.repo_id
JOIN repo_groups ON repo_groups.repo_group_id = repo.repo_group_id
WHERE
repo_groups.repo_group_id = :repo_group_id
Expand All @@ -111,6 +108,49 @@ def get_repos_in_repo_group(repo_group_id):
status=200,
mimetype="application/json")

@app.route('/{}/repos/<repo_id>'.format(AUGUR_API_VERSION))
def get_repo_by_id(repo_id: int) -> Response:
repo_by_id_SQL = s.sql.text("""
SELECT
repo.repo_id,
repo.repo_name,
repo.description,
repo.repo_git AS url,
a.commits_all_time,
b.issues_all_time,
c.pull_requests_all_time,
rg_name,
repo.repo_group_id
FROM
repo
LEFT OUTER JOIN
(SELECT * FROM api_get_all_repos_commits) a
ON repo.repo_id = a.repo_id
LEFT OUTER JOIN
(SELECT * FROM api_get_all_repos_issues) b
ON repo.repo_id = b.repo_id
LEFT OUTER JOIN
(SELECT * FROM api_get_all_repo_prs) c
ON repo.repo_id = c.repo_id
JOIN repo_groups ON repo_groups.repo_group_id = repo.repo_group_id
WHERE
repo.repo_id = :id
""")

results = pd.read_sql(repo_by_id_SQL, engine, params={"id": repo_id})
results["url"] = results["url"].apply(lambda datum: datum.split("//")[1]) # cut "https://" off the URL
results["base64_url"] = [base64.b64encode(results.at[i, "url"].encode()) for i in results.index]
data = results.to_json(orient="records", date_format="iso", date_unit="ms")

if not data or data == "[]":
return Response(response='{"status": "Repository ' + str(repo_id) + ' does not exist"}',
status=400,
mimetype="application/json")

return Response(response=data[1:-1], # cut off brackets at each end, turns list of length 1 into single value
status=200,
mimetype="application/json")

@app.route('/{}/owner/<owner>/repo/<repo>'.format(AUGUR_API_VERSION))
def get_repo_by_git_name(owner, repo):

Expand Down
13 changes: 12 additions & 1 deletion augur/api/view/api.py
Original file line number Diff line number Diff line change
@@ -1,23 +1,23 @@
from flask import Flask, render_template, render_template_string, request, abort, jsonify, redirect, url_for, session, flash

Check warning on line 1 in augur/api/view/api.py

View workflow job for this annotation

GitHub Actions / runner / pylint

[pylint] reported by reviewdog 🐶 C0114: Missing module docstring (missing-module-docstring) Raw Output: augur/api/view/api.py:1:0: C0114: Missing module docstring (missing-module-docstring)
import re
from flask_login import current_user, login_required
from augur.application.db.models import Repo, RepoGroup, UserGroup, UserRepo
from augur.tasks.frontend import add_org_repo_list, parse_org_and_repo_name, parse_org_name
from .utils import *

Check warning on line 6 in augur/api/view/api.py

View workflow job for this annotation

GitHub Actions / runner / pylint

[pylint] reported by reviewdog 🐶 E0402: Attempted relative import beyond top-level package (relative-beyond-top-level) Raw Output: augur/api/view/api.py:6:0: E0402: Attempted relative import beyond top-level package (relative-beyond-top-level)

Check warning on line 6 in augur/api/view/api.py

View workflow job for this annotation

GitHub Actions / runner / pylint

[pylint] reported by reviewdog 🐶 W0401: Wildcard import utils (wildcard-import) Raw Output: augur/api/view/api.py:6:0: W0401: Wildcard import utils (wildcard-import)
from ..server import app, engine

Check warning on line 7 in augur/api/view/api.py

View workflow job for this annotation

GitHub Actions / runner / pylint

[pylint] reported by reviewdog 🐶 E0402: Attempted relative import beyond top-level package (relative-beyond-top-level) Raw Output: augur/api/view/api.py:7:0: E0402: Attempted relative import beyond top-level package (relative-beyond-top-level)
from augur.application.db.session import DatabaseSession

@app.route('/cache/file/')
@app.route('/cache/file/<path:file>')
def cache(file=None):

Check warning on line 12 in augur/api/view/api.py

View workflow job for this annotation

GitHub Actions / runner / pylint

[pylint] reported by reviewdog 🐶 C0116: Missing function or method docstring (missing-function-docstring) Raw Output: augur/api/view/api.py:12:0: C0116: Missing function or method docstring (missing-function-docstring)
if file is None:
return redirect(url_for('static', filename="cache"))
return redirect(url_for('static', filename="cache/" + toCacheFilename(file, False)))

Check warning on line 15 in augur/api/view/api.py

View workflow job for this annotation

GitHub Actions / runner / pylint

[pylint] reported by reviewdog 🐶 E0602: Undefined variable 'toCacheFilename' (undefined-variable) Raw Output: augur/api/view/api.py:15:58: E0602: Undefined variable 'toCacheFilename' (undefined-variable)


def add_existing_repo_to_group(session, user_id, group_name, repo_id):

Check warning on line 18 in augur/api/view/api.py

View workflow job for this annotation

GitHub Actions / runner / pylint

[pylint] reported by reviewdog 🐶 C0116: Missing function or method docstring (missing-function-docstring) Raw Output: augur/api/view/api.py:18:0: C0116: Missing function or method docstring (missing-function-docstring)

Check warning on line 18 in augur/api/view/api.py

View workflow job for this annotation

GitHub Actions / runner / pylint

[pylint] reported by reviewdog 🐶 W0621: Redefining name 'session' from outer scope (line 1) (redefined-outer-name) Raw Output: augur/api/view/api.py:18:31: W0621: Redefining name 'session' from outer scope (line 1) (redefined-outer-name)

Check warning on line 18 in augur/api/view/api.py

View workflow job for this annotation

GitHub Actions / runner / pylint

[pylint] reported by reviewdog 🐶 R1710: Either all return statements in a function should return an expression, or none of them should. (inconsistent-return-statements) Raw Output: augur/api/view/api.py:18:0: R1710: Either all return statements in a function should return an expression, or none of them should. (inconsistent-return-statements)

logger.info("Adding existing repo to group")

Check warning on line 20 in augur/api/view/api.py

View workflow job for this annotation

GitHub Actions / runner / pylint

[pylint] reported by reviewdog 🐶 E0602: Undefined variable 'logger' (undefined-variable) Raw Output: augur/api/view/api.py:20:4: E0602: Undefined variable 'logger' (undefined-variable)

group_id = UserGroup.convert_group_name_to_id(session, user_id, group_name)
if group_id is None:
Expand Down Expand Up @@ -102,7 +102,18 @@
if rg_obj:
# add the orgs repos to the group
add_existing_org_to_group(session, current_user.user_id, group, rg_obj.repo_group_id)


# matches https://gitlab.com/{org}/{repo}/ or http://gitlab.com/{org}/{repo}
elif Repo.parse_gitlab_repo_url(url)[0]:

org_name, repo_name = Repo.parse_github_repo_url(url)
repo_git = f"https://gitlab.com/{org_name}/{repo_name}"

# TODO: gitlab ensure the whole repo git is inserted so it can be found here

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

[pylint] reported by reviewdog 🐶
W0511: TODO: gitlab ensure the whole repo git is inserted so it can be found here (fixme)

repo_obj = Repo.get_by_repo_git(session, repo_git)
if repo_obj:
add_existing_repo_to_group(session, current_user.user_id, group, repo_obj.repo_id)

else:
invalid_urls.append(url)

Expand Down
24 changes: 13 additions & 11 deletions augur/api/view/routes.py
Original file line number Diff line number Diff line change
@@ -1,4 +1,8 @@
"""
Defines the api routes for the augur views
"""
import logging
import math
from flask import Flask, render_template, render_template_string, request, abort, jsonify, redirect, url_for, session, flash
from sqlalchemy.orm.exc import NoResultFound
from .utils import *

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

[pylint] reported by reviewdog 🐶
E0402: Attempted relative import beyond top-level package (relative-beyond-top-level)

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

[pylint] reported by reviewdog 🐶
W0401: Wildcard import utils (wildcard-import)

Expand Down Expand Up @@ -37,9 +41,9 @@ def root(path=""):
def logo(brand=None):

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

[pylint] reported by reviewdog 🐶
C0116: Missing function or method docstring (missing-function-docstring)

if brand is None:
return redirect(url_for('static', filename='img/augur_logo.png'))
elif "augur" in brand:
if "augur" in brand:
return logo(None)
elif "chaoss" in brand:
if "chaoss" in brand:
return redirect(url_for('static', filename='img/Chaoss_Logo_white.png'))
return ""

Expand Down Expand Up @@ -74,17 +78,15 @@ def repo_table_view():
pagination_offset = config.get_value("frontend", "pagination_offset")

if current_user.is_authenticated:
data = load_repos_test(user = current_user, search = query, page = page, sort = sorting, direction = direction, source = "user")
page_count = load_repos_test(user = current_user, search = query, count = True, source = "user")
# data = current_user.get_repos(page = page, sort = sorting, direction = direction, search=query)[0]
# page_count = (current_user.get_repo_count(search = query)[0] or 0) // pagination_offset
data = current_user.get_repos(page = page, sort = sorting, direction = direction, search=query)[0]
repos_count = (current_user.get_repo_count(search = query)[0] or 0)
else:
data = load_repos_test(search = query, page = page, sort = sorting, direction = direction)
page_count = load_repos_test(search = query, count = True)
# data = get_all_repos(page = page, sort = sorting, direction = direction, search=query)[0]
# page_count = (get_all_repos_count(search = query)[0] or 0) // pagination_offset
data = get_all_repos(page = page, sort = sorting, direction = direction, search=query)[0]
repos_count = (get_all_repos_count(search = query)[0] or 0)

page_count = math.ceil(repos_count / pagination_offset) - 1

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

[pylint] reported by reviewdog 🐶
E0602: Undefined variable 'math' (undefined-variable)


if not data.count():
if not data:
data = None


Expand Down
70 changes: 7 additions & 63 deletions augur/api/view/utils.py
Original file line number Diff line number Diff line change
@@ -1,6 +1,10 @@
"""
Defines utility functions used by the augur api views
"""
from pathlib import Path
from concurrent.futures import ThreadPoolExecutor
from flask import render_template, flash, url_for, Flask
from .init import init_logging

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

[pylint] reported by reviewdog 🐶
E0402: Attempted relative import beyond top-level package (relative-beyond-top-level)

from .init import *

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

[pylint] reported by reviewdog 🐶
E0402: Attempted relative import beyond top-level package (relative-beyond-top-level)

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

[pylint] reported by reviewdog 🐶
W0401: Wildcard import init (wildcard-import)

from ..server import app, db_session

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

[pylint] reported by reviewdog 🐶
E0402: Attempted relative import beyond top-level package (relative-beyond-top-level)

from augur.application.config import AugurConfig
Expand All @@ -9,11 +13,13 @@
from augur.application.db.session import DatabaseSession

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

[pylint] reported by reviewdog 🐶
C0412: Imports from package augur are not grouped (ungrouped-imports)

from augur.application.db.engine import DatabaseEngine
from augur.application.db.models import User, Repo, RepoGroup, UserGroup, UserRepo
from sqlalchemy import Column, Table, Integer, MetaData, or_, Label
from sqlalchemy import Column, Table, Integer, MetaData, or_

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

[pylint] reported by reviewdog 🐶
E0401: Unable to import 'sqlalchemy' (import-error)

from sqlalchemy.sql.operators import ilike_op, distinct_op

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

[pylint] reported by reviewdog 🐶
E0401: Unable to import 'sqlalchemy.sql.operators' (import-error)

from sqlalchemy.sql.functions import coalesce

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

[pylint] reported by reviewdog 🐶
E0401: Unable to import 'sqlalchemy.sql.functions' (import-error)

from augur.application.db.models.base import Base

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

[pylint] reported by reviewdog 🐶
C0412: Imports from package augur are not grouped (ungrouped-imports)


from sqlalchemy.orm import Query

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

[pylint] reported by reviewdog 🐶
E0401: Unable to import 'sqlalchemy.orm' (import-error)

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

[pylint] reported by reviewdog 🐶
C0412: Imports from package sqlalchemy are not grouped (ungrouped-imports)


init_logging()

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

[pylint] reported by reviewdog 🐶
E0602: Undefined variable 'init_logging' (undefined-variable)


from .init import logger

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

[pylint] reported by reviewdog 🐶
E0402: Attempted relative import beyond top-level package (relative-beyond-top-level)

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

[pylint] reported by reviewdog 🐶
C0413: Import "from .init import logger" should be placed at the top of the module (wrong-import-position)

Expand Down Expand Up @@ -309,67 +315,5 @@ def render_module(module, **args):
args.setdefault("body", module)
return render_template('index.j2', **args)

""" ----------------------------------------------------------------
No longer used
"""
# My attempt at a loading page
def renderLoading(dest, query, request):
cache_files_requested.append(request)
return render_template('index.j2', body="loading", title="Loading", d=dest, query_key=query, api_url=getSetting('serving'))

with DatabaseEngine() as engine:
augur_data_schema = MetaData(schema = "augur_data")
augur_data_schema.reflect(bind = engine, views = True)

commits_materialized_view: Table = augur_data_schema.tables["augur_data.api_get_all_repos_commits"]
issues_materialized_view: Table = augur_data_schema.tables["augur_data.api_get_all_repos_issues"]

""" ----------------------------------------------------------------

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

[pylint] reported by reviewdog 🐶
W0105: String statement has no effect (pointless-string-statement)

"""
def load_repos_test(count = False, source = None, **kwargs):
columns: list[Label] = [
Repo.repo_id.distinct().label("repo_id"),
Repo.description.label("description"),
Repo.repo_git.label("url"),
coalesce(commits_materialized_view.columns.commits_all_time, 0).label("commits_all_time"),
coalesce(issues_materialized_view.columns.issues_all_time, 0).label("issues_all_time"),
RepoGroup.rg_name.label("rg_name"),
Repo.repo_git.regexp_replace('.*github\.com\/[A-Za-z0-9 \- _]+\/([A-Za-z0-9 \- _ .]+)$', "\\1").label("repo_name"),
Repo.repo_git.regexp_replace('.*github\.com\/([A-Za-z0-9 \- _]+)\/[A-Za-z0-9 \- _ .]+$', "\\1").label("repo_owner"),
RepoGroup.repo_group_id.label("repo_group_id")
]

def get_colum_by_label(label: str)-> Label:
for column in columns:
if column.name == label:
return column

repos = db_session.query(*columns)\
.outerjoin(commits_materialized_view, Repo.repo_id == commits_materialized_view.columns.repo_id)\
.outerjoin(issues_materialized_view, Repo.repo_id == issues_materialized_view.columns.repo_id)\
.join(RepoGroup, Repo.repo_group_id == RepoGroup.repo_group_id)

user: User = kwargs.get("user")
if user:
repos = repos.join(UserRepo, Repo.repo_id == UserRepo.repo_id)\
.join(UserGroup, UserGroup.group_id == UserRepo.group_id)\
.filter(UserGroup.user_id == user.user_id)

search = kwargs.get("search")
qkey = kwargs.get("query_key") or ["repo_name", "repo_owner"]
if search:
if isinstance(qkey, list) and len(qkey) > 0:
repos = repos.filter(or_(ilike_op(get_colum_by_label(filter_column), f"%{search}%") for filter_column in qkey))
else:
repos = repos.filter(ilike_op(get_colum_by_label(qkey), f"%{search}%"))

page_size: int = kwargs.get("page_size") or 25
if count:
c = repos.count()
return math.ceil(c / page_size) - 1

page: int = kwargs.get("page") or 0
offset = page * page_size

return repos.slice(offset, offset + page_size)

9 changes: 6 additions & 3 deletions augur/application/cli/backend.py
Original file line number Diff line number Diff line change
Expand Up @@ -91,9 +91,12 @@ def start(disable_collection, development, port):
logger.info("Deleting old task schedule")
os.remove("celerybeat-schedule.db")

celery_beat_process = None
celery_command = "celery -A augur.tasks.init.celery_app.celery_app beat -l debug"
celery_beat_process = subprocess.Popen(celery_command.split(" "))
with DatabaseSession(logger) as db_session:
config = AugurConfig(logger, db_session)
log_level = config.get_value("Logging", "log_level")
celery_beat_process = None
celery_command = f"celery -A augur.tasks.init.celery_app.celery_app beat -l {log_level.lower()}"
celery_beat_process = subprocess.Popen(celery_command.split(" "))

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

[pylint] reported by reviewdog 🐶
R1732: Consider using 'with' for resource-allocating operations (consider-using-with)


if not disable_collection:

Expand Down
Loading
Loading