Skip to content

Commit

Permalink
Merge branch 'main' into dependabot/npm_and_yarn/taxonomy-editor-fron…
Browse files Browse the repository at this point in the history
…tend/typescript-5.5.4
  • Loading branch information
alexgarel authored Dec 20, 2024
2 parents 3144c50 + 42d69ba commit b5ffc3f
Show file tree
Hide file tree
Showing 34 changed files with 3,497 additions and 1,663 deletions.
3 changes: 3 additions & 0 deletions .env
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,9 @@ COMPOSE_FILE=docker-compose.yml;docker/dev.yml
# version
DOCKER_TAG=dev

# no restart on dev mode (we want to launch containers only on demand)
RESTART_POLICY=no

# domain name
TAXONOMY_EDITOR_DOMAIN=taxonomy.localhost
# exposition
Expand Down
22 changes: 11 additions & 11 deletions .github/labeler.yml
Original file line number Diff line number Diff line change
@@ -1,11 +1,11 @@
# Add labels to any any pull request with changes to the specified paths
# for reference, see https://github.com/actions/labeler

github:
GitHub:
- changed-files:
- any-glob-to-any-file: ".github/**/*"

documentation:
📚 Documentation:
- changed-files:
- any-glob-to-any-file: "CONTRIBUTING.md"
- any-glob-to-any-file: "LICENSE"
Expand All @@ -18,14 +18,14 @@ documentation:
- any-glob-to-any-file: "doc/assets/.empty"
- any-glob-to-any-file: "doc/**/*"

docker:
🐳 Docker:
- changed-files:
- any-glob-to-any-file: "backend/Dockerfile"
- any-glob-to-any-file: "taxonomy-editor-frontend/Dockerfile"
- any-glob-to-any-file: "docker-compose.yml"
- any-glob-to-any-file: "docker/dev.yml"

backend:
Backend:
- changed-files:
- any-glob-to-any-file: "backend/editor/__init__.py"
- any-glob-to-any-file: "backend/editor/api.py"
Expand All @@ -44,31 +44,31 @@ backend:
- any-glob-to-any-file: "backend/sample/test.txt"
- any-glob-to-any-file: "backend/**/*"

frontend:
Frontend:
- changed-files:
- any-glob-to-any-file: "taxonomy-editor-frontend/**/*"

dependencies:
Dependencies:
- changed-files:
- any-glob-to-any-file: "backend/pyproject.toml"
- any-glob-to-any-file: "backend/poetry.lock"
- any-glob-to-any-file: "parser/pyproject.toml"
- any-glob-to-any-file: "parser/poetry.lock"
- any-glob-to-any-file: "taxonomy-editor-frontend/package.json"

api:
API:
- changed-files:
- any-glob-to-any-file: "backend/editor/api.py"

nginx:
NGINX:
- changed-files:
- any-glob-to-any-file: "conf/nginx.conf"

neo4j:
Neo4j:
- changed-files:
- any-glob-to-any-file: "neo4j/**/*"

parser:
Parser:
- changed-files:
- any-glob-to-any-file: "parser/Makefile"
- any-glob-to-any-file: "parser/openfoodfacts_taxonomy_parser/__init__.py"
Expand All @@ -84,7 +84,7 @@ parser:
- any-glob-to-any-file: "parser/tests/integration/__init__.py"
- any-glob-to-any-file: "parser/**/*"

tests:
🧪 tests:
- any-glob-to-any-file: "parser/tests/__init__.py"
- any-glob-to-any-file: "parser/tests/conftest.py"
- any-glob-to-any-file: "parser/tests/data/test.txt"
Expand Down
94 changes: 90 additions & 4 deletions .github/workflows/github-projects-for-openfoodfacts-design.yml
Original file line number Diff line number Diff line change
@@ -1,24 +1,110 @@
name: Add mockup-required and mockup-available issues to the openfoodfacts-design project
name: 🎨 Add Mockup required and Mockup available issues to the openfoodfacts-design project

on:
issues:
types:
- labeled
- edited
- transfered

jobs:
add-to-project:
name: Add issue to the openfoodfacts-design project
name: Add issues to the 🎨 openfoodfacts-design or 📚 documentation project
runs-on: ubuntu-latest
steps:
- uses: actions/add-to-project@main
with:
project-url: https://github.com/orgs/openfoodfacts/projects/11
github-token: ${{ secrets.ADD_TO_PROJECT_PAT }}
labeled: mockups available, needs mockup
labeled: 🎨 Mockup available, 🎨 Mockup required
label-operator: OR
- uses: actions/add-to-project@main
with:
project-url: https://github.com/orgs/openfoodfacts/projects/25 # Add issue to the documentation project
github-token: ${{ secrets.ADD_TO_PROJECT_PAT }}
labeled: documentation
labeled: 📚 documentation
label-operator: OR
- uses: actions/add-to-project@main
with:
project-url: https://github.com/orgs/openfoodfacts/projects/36 # Add issue to the open pet food facts project
github-token: ${{ secrets.ADD_TO_PROJECT_PAT }}
labeled: 🐾 Open Pet Food Facts
label-operator: OR
- uses: actions/add-to-project@main
with:
project-url: https://github.com/orgs/openfoodfacts/projects/11 # Add issue to the open products facts project
github-token: ${{ secrets.ADD_TO_PROJECT_PAT }}
labeled: 📸 Open Products Facts
label-operator: OR
- uses: actions/add-to-project@main
with:
project-url: https://github.com/orgs/openfoodfacts/projects/37 # Add issue to the open beauty facts project
github-token: ${{ secrets.ADD_TO_PROJECT_PAT }}
labeled: 🧴 Open Beauty Facts
label-operator: OR
- uses: actions/add-to-project@main
with:
project-url: https://github.com/orgs/openfoodfacts/projects/4 # Add issue to the packaging project
github-token: ${{ secrets.ADD_TO_PROJECT_PAT }}
labeled: 📦 Packaging
label-operator: OR
- uses: actions/add-to-project@main
with:
project-url: https://github.com/orgs/openfoodfacts/projects/25 # Add issue to the documentation project
github-token: ${{ secrets.ADD_TO_PROJECT_PAT }}
labeled: 📚 Documentation
label-operator: OR
- uses: actions/add-to-project@main
with:
project-url: https://github.com/orgs/openfoodfacts/projects/5 # Add issue to the folksonomy project
github-token: ${{ secrets.ADD_TO_PROJECT_PAT }}
labeled: 🏷️ Folksonomy Project
label-operator: OR
- uses: actions/add-to-project@main
with:
project-url: https://github.com/orgs/openfoodfacts/projects/44 # Add issue to the data quality project
github-token: ${{ secrets.ADD_TO_PROJECT_PAT }}
labeled: 🧽 Data quality
label-operator: OR
- uses: actions/add-to-project@main
with:
project-url: https://github.com/orgs/openfoodfacts/projects/82 # Add issue to the search project
github-token: ${{ secrets.ADD_TO_PROJECT_PAT }}
labeled: 🔎 Search
label-operator: OR
- uses: actions/add-to-project@main
with:
project-url: https://github.com/orgs/openfoodfacts/projects/41 # Add issue to the producer platform project
github-token: ${{ secrets.ADD_TO_PROJECT_PAT }}
labeled: 🏭 Producers Platform
label-operator: OR
- uses: actions/add-to-project@main
with:
project-url: https://github.com/orgs/openfoodfacts/projects/19 # Add issue to the infrastructure project
github-token: ${{ secrets.ADD_TO_PROJECT_PAT }}
labeled: infrastructure
label-operator: OR
- uses: actions/add-to-project@main
with:
project-url: https://github.com/orgs/openfoodfacts/projects/92 # Add issue to the Nutri-Score project
github-token: ${{ secrets.ADD_TO_PROJECT_PAT }}
labeled: 🚦 Nutri-Score
label-operator: OR
- uses: actions/add-to-project@main
with:
project-url: https://github.com/orgs/openfoodfacts/projects/132 # Add issue to the Top upvoted issues board
github-token: ${{ secrets.ADD_TO_PROJECT_PAT }}
labeled: ⭐ top issue, 👍 Top 10 Issue!
label-operator: OR
- uses: actions/add-to-project@main
with:
project-url: https://github.com/orgs/openfoodfacts/projects/57 # Add issue to the Most impactful issues board
github-token: ${{ secrets.ADD_TO_PROJECT_PAT }}
labeled: 🎯 P0, 🎯 P1
label-operator: OR
- uses: actions/add-to-project@main
with:
project-url: https://github.com/orgs/openfoodfacts/projects/35 # Add issue to the ♿️ accessibility project
github-token: ${{ secrets.ADD_TO_PROJECT_PAT }}
labeled: ♿️ accessibility
label-operator: OR
13 changes: 9 additions & 4 deletions Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -99,9 +99,14 @@ local_config_quality: ## Run on lint configuration files

build: ## Build docker images
@echo "🍜 Building docker images"
${DOCKER_COMPOSE} build
${DOCKER_COMPOSE} build ${args}
@echo "🍜 Project setup done"

backend_poetry_update: ## Update poetry.lock file
@echo "🍜 Updating poetry.lock file"
${DOCKER_COMPOSE} run --user root --rm taxonomy_api bash -c "pip install poetry==1.4.2 && poetry lock --no-update"


up: ## Run the project
@echo "🍜 Running project (ctrl+C to stop)"
@echo "🍜 The React app will be available on http://ui.taxonomy.localhost:8091"
Expand Down Expand Up @@ -177,11 +182,11 @@ config_quality: ## Run quality checks on configuration files

tests: backend_tests ## Run all tests

backend_tests: ## Run python tests
backend_tests: ## Run python tests, you might provide additional arguments with args="…"
@echo "🍜 Running python tests"
${DOCKER_COMPOSE_TEST} up -d neo4j
${DOCKER_COMPOSE_TEST} run --rm taxonomy_api pytest /parser
${DOCKER_COMPOSE_TEST} run --rm taxonomy_api pytest /code/tests
${DOCKER_COMPOSE_TEST} run --rm taxonomy_api pytest /parser ${args}
${DOCKER_COMPOSE_TEST} run --rm taxonomy_api pytest /code/tests ${args}
${DOCKER_COMPOSE_TEST} stop neo4j

checks: quality tests ## Run all checks (quality + tests)
Expand Down
22 changes: 11 additions & 11 deletions backend/editor/api.py
Original file line number Diff line number Diff line change
Expand Up @@ -184,7 +184,7 @@ async def find_all_nodes(response: Response, branch: str, taxonomy_name: str):
Get all nodes within taxonomy
"""
taxonomy = TaxonomyGraph(branch, taxonomy_name)
all_nodes = await taxonomy.get_all_nodes("")
all_nodes = await taxonomy.get_all_nodes()
return all_nodes


Expand Down Expand Up @@ -235,7 +235,7 @@ async def find_one_synonym(response: Response, branch: str, taxonomy_name: str,
Get synonym corresponding to id within taxonomy
"""
taxonomy = TaxonomyGraph(branch, taxonomy_name)
one_synonym = await taxonomy.get_nodes("SYNONYMS", synonym)
one_synonym = await taxonomy.get_nodes(NodeType.SYNONYMS, synonym)

check_single(one_synonym)

Expand All @@ -248,7 +248,7 @@ async def find_all_synonyms(response: Response, branch: str, taxonomy_name: str)
Get all synonyms within taxonomy
"""
taxonomy = TaxonomyGraph(branch, taxonomy_name)
all_synonyms = await taxonomy.get_all_nodes("SYNONYMS")
all_synonyms = await taxonomy.get_all_nodes(NodeType.SYNONYMS)
return all_synonyms


Expand All @@ -258,7 +258,7 @@ async def find_one_stopword(response: Response, branch: str, taxonomy_name: str,
Get stopword corresponding to id within taxonomy
"""
taxonomy = TaxonomyGraph(branch, taxonomy_name)
one_stopword = await taxonomy.get_nodes("STOPWORDS", stopword)
one_stopword = await taxonomy.get_nodes(NodeType.STOPWORDS, stopword)

check_single(one_stopword)

Expand All @@ -271,7 +271,7 @@ async def find_all_stopwords(response: Response, branch: str, taxonomy_name: str
Get all stopwords within taxonomy
"""
taxonomy = TaxonomyGraph(branch, taxonomy_name)
all_stopwords = await taxonomy.get_all_nodes("STOPWORDS")
all_stopwords = await taxonomy.get_all_nodes(NodeType.STOPWORDS)
return all_stopwords


Expand All @@ -281,7 +281,7 @@ async def find_header(response: Response, branch: str, taxonomy_name: str):
Get __header__ within taxonomy
"""
taxonomy = TaxonomyGraph(branch, taxonomy_name)
header = await taxonomy.get_nodes("TEXT", "__header__")
header = await taxonomy.get_nodes(NodeType.TEXT, "__header__")
return header[0]


Expand All @@ -291,7 +291,7 @@ async def find_footer(response: Response, branch: str, taxonomy_name: str):
Get __footer__ within taxonomy
"""
taxonomy = TaxonomyGraph(branch, taxonomy_name)
footer = await taxonomy.get_nodes("TEXT", "__footer__")
footer = await taxonomy.get_nodes(NodeType.TEXT, "__footer__")
return footer[0]


Expand Down Expand Up @@ -395,7 +395,7 @@ async def upload_taxonomy(
"""
taxonomy = TaxonomyGraph(branch, taxonomy_name)
if not taxonomy.is_valid_branch_name():
raise HTTPException(status_code=422, detail="branch_name: Enter a valid branch name!")
raise HTTPException(status_code=422, detail="branch_name: Enter a valid branch name!")
if await taxonomy.does_project_exist():
raise HTTPException(status_code=409, detail="Project already exists!")
if not await taxonomy.is_branch_unique(from_github=False):
Expand Down Expand Up @@ -431,7 +431,7 @@ async def edit_entry(request: Request, branch: str, taxonomy_name: str, entry: s
incoming_data = await request.json()
incoming_data["id"] = entry
new_entry = EntryNode(**incoming_data)
updated_entry = await taxonomy.update_node("ENTRY", new_entry)
updated_entry = await taxonomy.update_node(NodeType.ENTRY, new_entry)
return updated_entry


Expand Down Expand Up @@ -467,5 +467,5 @@ async def delete_project(branch: str, taxonomy_name: str):
"""
Delete a project
"""
taxonomy = TaxonomyGraph(branch, taxonomy_name)
await project_controller.delete_project(taxonomy.project_name)
project_id = project_controller.get_project_id(branch, taxonomy_name)
await project_controller.delete_project(project_id)
5 changes: 4 additions & 1 deletion backend/editor/controllers/node_controller.py
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
import datetime
import logging

from openfoodfacts_taxonomy_parser import utils as parser_utils
Expand All @@ -12,7 +13,7 @@
async def delete_project_nodes(project_id: str):
"""
Remove all nodes for project.
This includes entries, stopwords, synonyms and errors
This includes entries, stopwords, synonyms, errors and removed entries
"""

query = f"""
Expand All @@ -38,6 +39,8 @@ async def create_entry_node(
"id": language_code + ":" + normalized_name,
f"tags_{language_code}": [name],
f"tags_ids_{language_code}": [normalized_name],
"modified": datetime.datetime.now().timestamp(),
"is_external": False,
}
params = {"entry_node": entry_node_data}

Expand Down
43 changes: 43 additions & 0 deletions backend/editor/controllers/project_controller.py
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,10 @@
from .utils.result_utils import get_unique_record


def get_project_id(branch_name: str, taxonomy_name: str) -> str:
return "p_" + taxonomy_name + "_" + branch_name


async def get_project(project_id: str) -> Project:
"""
Get project by id
Expand Down Expand Up @@ -78,3 +82,42 @@ async def delete_project(project_id: str):
params = {"project_id": project_id}
await get_current_transaction().run(query, params)
await delete_project_nodes(project_id)


async def clone_project(source_branch: str, taxonomy_name: str, target_branch: str):
"""
Clone a project using a new branch name
Currently used for tests only.
"""
source_id = get_project_id(source_branch, taxonomy_name)
target_id = get_project_id(target_branch, taxonomy_name)
# clone project node
query = """
MATCH (p:PROJECT {id: $project_id})
WITH p
CALL apoc.refactor.cloneNodes([p], true, ['id', 'branch'] )
YIELD output as new_node
WITH new_node
SET new_node.created_at = datetime(),
new_node.branch_name = $target_branch,
new_node.id = $target_id
RETURN new_node
"""
params = {
"project_id": source_id,
"target_branch": target_branch,
"target_id": get_project_id(target_branch, taxonomy_name),
}
await get_current_transaction().run(query, params)
# clone nodes thanks to apoc.refactor.cloneSubgraph
query = f"""
MATCH (n:{source_id})
WITH collect(n) AS source_nodes
CALL apoc.refactor.cloneSubgraph(source_nodes)
YIELD output as new_node
WITH new_node
REMOVE new_node:{source_id}
SET new_node:{target_id}
"""
await get_current_transaction().run(query)
Loading

0 comments on commit b5ffc3f

Please sign in to comment.