Skill flagged — suspicious patterns detected

ClawHub Security flagged this skill as suspicious. Review the scan results before using.

eCTD XML Compiler

v1.0.0

Automatically convert uploaded drug application documents (Word/PDF) into XML skeleton structure compliant with eCTD 4.0/3.2.2 specifications.

0· 87·0 current·0 all-time
byAIpoch@aipoch-ai

Install

OpenClaw Prompt Flow

Install with OpenClaw

Best for remote or guided setup. Copy the exact prompt, then paste it into OpenClaw for aipoch-ai/ectd-xml-compiler.

Previewing Install & Setup.
Prompt PreviewInstall & Setup
Install the skill "eCTD XML Compiler" (aipoch-ai/ectd-xml-compiler) from ClawHub.
Skill page: https://clawhub.ai/aipoch-ai/ectd-xml-compiler
Keep the work scoped to this skill only.
After install, inspect the skill metadata and help me finish setup.
Use only the metadata you can verify from ClawHub; do not invent missing requirements.
Ask before making any broader environment changes.

Command Line

CLI Commands

Use the direct CLI path if you want to install manually and keep every step visible.

OpenClaw CLI

Bare skill slug

openclaw skills install ectd-xml-compiler

ClawHub CLI

Package manager switcher

npx clawhub@latest install ectd-xml-compiler
Security Scan
VirusTotalVirusTotal
Benign
View report →
OpenClawOpenClaw
Suspicious
medium confidence
Purpose & Capability
Name, description, and the included script align with converting Word/PDF into eCTD XML skeletons. However there are small mismatches: SKILL.md and requirements mention support for '.doc' files, but the implementation relies on python-docx which only handles .docx; requirements.txt lists 'docx' and 'pypdf2' (lowercase) which do not precisely match the commonly used pip package names ('python-docx' and 'PyPDF2'). These are coherence/maintenance issues rather than evidence of malicious intent.
Instruction Scope
SKILL.md gives explicit, scoped runtime instructions (run py_compile, run the script with arguments, confirm I/O). It does not instruct reading unrelated system files or environment variables, nor does it specify external network endpoints. The instructions do recommend editing an in-file CONFIG block if present — you should verify whether that block exists and what it changes before editing or running.
Install Mechanism
There is no install spec that downloads remote code; the package is instruction-only with bundled Python code and a requirements.txt. This is a lower-risk install model. Note: the requirements file may reference inexact package names which could cause confusion when installing dependencies.
Credentials
The skill does not request environment variables, credentials, or config paths. All declared and implied needs (local file input and local output directory) are proportionate to the stated purpose.
Persistence & Privilege
The skill is not always-enabled and is user-invocable. It does not request persistent system-wide privileges or modify other skills. Autonomous invocation is allowed by default but that alone is not a red flag here.
What to consider before installing
This package appears to implement the advertised eCTD XML skeleton conversion, but there are multiple quality and coherence issues you should address before using it on real or sensitive documents: - Do not run on sensitive production submissions until you audit the code. Review scripts/main.py fully for any unexpected I/O or network calls (the visible portion shows no network activity but the file is truncated in the listing). - Confirm dependency names and install into an isolated virtual environment. requirements.txt lists 'docx' and 'pypdf2' while the code expects python-docx and PyPDF2; install the correct packages (pip install python-docx PyPDF2 lxml) and test imports. - Test with non-sensitive sample documents. The code contains clear bugs (for example, in generate_xml it references module_dir before it is defined) and may raise runtime errors or produce incomplete output. Run python -m py_compile scripts/main.py and then execute with small inputs to see behavior. - Check that the script does not modify files outside the intended output directory and that any CONFIG block it mentions is safe to edit (search the repository for CONFIG). If the script writes or overwrites files, back up originals first. - Confirm .doc support: the tool claims .doc support but python-docx does not parse legacy .doc files; convert .doc to .docx before feeding it in or verify fallback behavior. - Verify MD5 usage: the tool writes MD5 checksums for integrity; be aware MD5 is not cryptographically secure for tamper detection, but is commonly used for simple checksums. If you are not comfortable auditing the code yourself, ask the developer for clarification (source repository, full script, and corrected dependency list) or run the tool inside a sandboxed environment (isolated VM/container) before trusting outputs for regulatory submissions.

Like a lobster shell, security has layers — review code before you run it.

latestvk971t3s4p9c68tt23ja8dfz9sh8413am
87downloads
0stars
1versions
Updated 3w ago
v1.0.0
MIT-0

eCTD XML Compiler

ID: 197

Automatically convert uploaded drug application documents (Word/PDF) into XML skeleton structure compliant with eCTD 4.0/3.2.2 specifications.

When to Use

  • Use this skill when the task needs Automatically convert uploaded drug application documents (Word/PDF) into XML skeleton structure compliant with eCTD 4.0/3.2.2 specifications.
  • Use this skill for academic writing tasks that require explicit assumptions, bounded scope, and a reproducible output format.
  • Use this skill when you need a documented fallback path for missing inputs, execution errors, or partial evidence.

Key Features

  • Scope-focused workflow aligned to: Automatically convert uploaded drug application documents (Word/PDF) into XML skeleton structure compliant with eCTD 4.0/3.2.2 specifications.
  • Packaged executable path(s): scripts/main.py.
  • Reference material available in references/ for task-specific guidance.
  • Structured execution path designed to keep outputs consistent and reviewable.

Dependencies

python-docx>=0.8.11    # Word document parsing
PyPDF2>=3.0.0          # PDF text extraction
lxml>=4.9.0            # XML processing

Example Usage

See ## Usage above for related details.

cd "20260318/scientific-skills/Academic Writing/ectd-xml-compiler"
python -m py_compile scripts/main.py
python scripts/main.py --help

Example run plan:

  1. Confirm the user input, output path, and any required config values.
  2. Edit the in-file CONFIG block or documented parameters if the script uses fixed settings.
  3. Run python scripts/main.py with the validated inputs.
  4. Review the generated output and return the final artifact with any assumptions called out.

Implementation Details

See ## Workflow above for related details.

  • Execution model: validate the request, choose the packaged workflow, and produce a bounded deliverable.
  • Input controls: confirm the source files, scope limits, output format, and acceptance criteria before running any script.
  • Primary implementation surface: scripts/main.py.
  • Reference guidance: references/ contains supporting rules, prompts, or checklists.
  • Parameters to clarify first: input path, output path, scope filters, thresholds, and any domain-specific constraints.
  • Output discipline: keep results reproducible, identify assumptions explicitly, and avoid undocumented side effects.

Quick Check

Use this command to verify that the packaged script entry point can be parsed before deeper execution.

python -m py_compile scripts/main.py

Audit-Ready Commands

Use these concrete commands for validation. They are intentionally self-contained and avoid placeholder paths.

python -m py_compile scripts/main.py
python scripts/main.py --help

Workflow

  1. Confirm the user objective, required inputs, and non-negotiable constraints before doing detailed work.
  2. Validate that the request matches the documented scope and stop early if the task would require unsupported assumptions.
  3. Use the packaged script path or the documented reasoning path with only the inputs that are actually available.
  4. Return a structured result that separates assumptions, deliverables, risks, and unresolved items.
  5. If execution fails or inputs are incomplete, switch to the fallback path and state exactly what blocked full completion.

Overview

eCTD (electronic Common Technical Document) is the electronic Common Technical Document standard established by ICH for submitting drug registration applications to regulatory agencies such as FDA and EMA.

This tool parses uploaded drug application documents (Word/PDF) and converts them into XML skeleton structure compliant with eCTD 4.0/3.2.2 specifications.

eCTD Structure

eCTD/
├── m1/  # Module 1: Administrative Information and Prescribing Information (region-specific)
│   ├── m1.xml
│   └── ...
├── m2/  # Module 2: CTD Summaries
│   ├── m2.xml
│   └── ...
├── m3/  # Module 3: Quality
│   ├── m3.xml
│   └── ...
├── m4/  # Module 4: Nonclinical Study Reports
│   ├── m4.xml
│   └── ...
├── m5/  # Module 5: Clinical Study Reports
│   ├── m5.xml
│   └── ...
├── index.xml      # Master index file
├── index-md5.txt  # MD5 checksum file
└── dtd/           # DTD files

Usage

python skills/ectd-xml-compiler/scripts/main.py [options] <input_files...>

Arguments

ArgumentDescription
input_filesInput Word/PDF file paths (supports multiple)

Options

OptionShortDescriptionDefault
--output-oOutput directory path./ectd-output
--module-mTarget module (m1-m5, auto)auto
--region-rTarget region (FDA, EMA, ICH)ICH
--version-veCTD version (3.2.2, 4.0)4.0
--dtd-path-dCustom DTD pathBuilt-in DTD
--validateValidate generated XMLFalse

Examples


# Basic usage - auto-detect module
python skills/ectd-xml-compiler/scripts/main.py document1.docx document2.pdf

# Specify output directory and module
python skills/ectd-xml-compiler/scripts/main.py -o ./my-ectd -m m3 quality-doc.docx

# FDA submission format
python skills/ectd-xml-compiler/scripts/main.py -r FDA -v 3.2.2 *.pdf

# Validate generated XML
python skills/ectd-xml-compiler/scripts/main.py --validate submission.pdf

Input Document Processing

Supported Formats

  • Microsoft Word (.docx, .doc)
  • PDF (.pdf)

Document Parsing Logic

  1. Title Recognition: Extract heading hierarchy based on font size and style
  2. TOC Mapping: Auto-recognize section numbers (e.g., 3.2.S.1.1)
  3. Metadata Extraction: Extract author, date, version, and other information
  4. Content Classification: Map to corresponding eCTD modules based on keyword matching

Module Auto-Recognition Rules

Keyword PatternTarget Module
Administrative, Label, Package Insertm1
Summary, summary, Overviewm2
Quality, quality, CMC, API, Drug Productm3
Nonclinical, Toxicology, Pharmacokineticsm4
Clinical, clinical, Study, Trialm5

Output Structure

Generated eCTD skeleton contains:

index.xml

Master index file containing references and sequence information for all modules.

Module XML (m1.xml - m5.xml)

XML skeleton for each module, containing:

  • Document hierarchy structure (<leaf>, <node>)
  • Cross-references (<cross-reference>)
  • Attribute definitions (ID, version, operation type)

MD5 Checksums

MD5 checksum values for each file to ensure integrity.

Installation


# Install dependencies
pip install python-docx PyPDF2 lxml

Validation

Using --validate option can validate generated XML:

  • DTD structure validation
  • Required elements and attributes check
  • Cross-reference integrity check

References

License

MIT License

Risk Assessment

Risk IndicatorAssessmentLevel
Code ExecutionPython/R scripts executed locallyMedium
Network AccessNo external API callsLow
File System AccessRead input files, write output filesMedium
Instruction TamperingStandard prompt guidelinesLow
Data ExposureOutput files saved to workspaceLow

Security Checklist

  • No hardcoded credentials or API keys
  • No unauthorized file system access (../)
  • Output does not expose sensitive information
  • Prompt injection protections in place
  • Input file paths validated (no ../ traversal)
  • Output directory restricted to workspace
  • Script execution in sandboxed environment
  • Error messages sanitized (no stack traces exposed)
  • Dependencies audited

Prerequisites

No additional Python packages required.

Evaluation Criteria

Success Metrics

  • Successfully executes main functionality
  • Output meets quality standards
  • Handles edge cases gracefully
  • Performance is acceptable

Test Cases

  1. Basic Functionality: Standard input → Expected output
  2. Edge Case: Invalid input → Graceful error handling
  3. Performance: Large dataset → Acceptable processing time

Lifecycle Status

  • Current Stage: Draft
  • Next Review Date: 2026-03-06
  • Known Issues: None
  • Planned Improvements:
    • Performance optimization
    • Additional feature support

Output Requirements

Every final response should make these items explicit when they are relevant:

  • Objective or requested deliverable
  • Inputs used and assumptions introduced
  • Workflow or decision path
  • Core result, recommendation, or artifact
  • Constraints, risks, caveats, or validation needs
  • Unresolved items and next-step checks

Error Handling

  • If required inputs are missing, state exactly which fields are missing and request only the minimum additional information.
  • If the task goes outside the documented scope, stop instead of guessing or silently widening the assignment.
  • If scripts/main.py fails, report the failure point, summarize what still can be completed safely, and provide a manual fallback.
  • Do not fabricate files, citations, data, search results, or execution outcomes.

Input Validation

This skill accepts requests that match the documented purpose of ectd-xml-compiler and include enough context to complete the workflow safely.

Do not continue the workflow when the request is out of scope, missing a critical input, or would require unsupported assumptions. Instead respond:

ectd-xml-compiler only handles its documented workflow. Please provide the missing required inputs or switch to a more suitable skill.

References

Response Template

Use the following fixed structure for non-trivial requests:

  1. Objective
  2. Inputs Received
  3. Assumptions
  4. Workflow
  5. Deliverable
  6. Risks and Limits
  7. Next Checks

If the request is simple, you may compress the structure, but still keep assumptions and limits explicit when they affect correctness.

Comments

Loading comments...