← Back to Skills Marketplace
aipoch-ai

eCTD XML Compiler

by AIpoch · GitHub ↗ · v1.0.0 · MIT-0
cross-platform ⚠ suspicious
90
Downloads
0
Stars
0
Active Installs
1
Versions
Install in OpenClaw
/install ectd-xml-compiler
Description
Automatically convert uploaded drug application documents (Word/PDF) into XML skeleton structure compliant with eCTD 4.0/3.2.2 specifications.
README (SKILL.md)

\r

eCTD XML Compiler\r

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

When to Use\r

\r

  • 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.\r
  • Use this skill for academic writing tasks that require explicit assumptions, bounded scope, and a reproducible output format.\r
  • Use this skill when you need a documented fallback path for missing inputs, execution errors, or partial evidence.\r \r

Key Features\r

\r

  • 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.\r
  • Packaged executable path(s): scripts/main.py.\r
  • Reference material available in references/ for task-specific guidance.\r
  • Structured execution path designed to keep outputs consistent and reviewable.\r \r

Dependencies\r

\r

python-docx>=0.8.11    # Word document parsing\r
PyPDF2>=3.0.0          # PDF text extraction\r
lxml>=4.9.0            # XML processing\r
```\r
\r
## Example Usage\r
\r
See `## Usage` above for related details.\r
\r
```bash\r
cd "20260318/scientific-skills/Academic Writing/ectd-xml-compiler"\r
python -m py_compile scripts/main.py\r
python scripts/main.py --help\r
```\r
\r
Example run plan:\r
1. Confirm the user input, output path, and any required config values.\r
2. Edit the in-file `CONFIG` block or documented parameters if the script uses fixed settings.\r
3. Run `python scripts/main.py` with the validated inputs.\r
4. Review the generated output and return the final artifact with any assumptions called out.\r
\r
## Implementation Details\r
\r
See `## Workflow` above for related details.\r
\r
- Execution model: validate the request, choose the packaged workflow, and produce a bounded deliverable.\r
- Input controls: confirm the source files, scope limits, output format, and acceptance criteria before running any script.\r
- Primary implementation surface: `scripts/main.py`.\r
- Reference guidance: `references/` contains supporting rules, prompts, or checklists.\r
- Parameters to clarify first: input path, output path, scope filters, thresholds, and any domain-specific constraints.\r
- Output discipline: keep results reproducible, identify assumptions explicitly, and avoid undocumented side effects.\r
\r
## Quick Check\r
\r
Use this command to verify that the packaged script entry point can be parsed before deeper execution.\r
\r
```bash\r
python -m py_compile scripts/main.py\r
```\r
\r
## Audit-Ready Commands\r
\r
Use these concrete commands for validation. They are intentionally self-contained and avoid placeholder paths.\r
\r
```bash\r
python -m py_compile scripts/main.py\r
python scripts/main.py --help\r
```\r
\r
## Workflow\r
\r
1. Confirm the user objective, required inputs, and non-negotiable constraints before doing detailed work.\r
2. Validate that the request matches the documented scope and stop early if the task would require unsupported assumptions.\r
3. Use the packaged script path or the documented reasoning path with only the inputs that are actually available.\r
4. Return a structured result that separates assumptions, deliverables, risks, and unresolved items.\r
5. If execution fails or inputs are incomplete, switch to the fallback path and state exactly what blocked full completion.\r
\r
## Overview\r
\r
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.\r
\r
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.\r
\r
## eCTD Structure\r
\r
```\r
eCTD/\r
├── m1/  # Module 1: Administrative Information and Prescribing Information (region-specific)\r
│   ├── m1.xml\r
│   └── ...\r
├── m2/  # Module 2: CTD Summaries\r
│   ├── m2.xml\r
│   └── ...\r
├── m3/  # Module 3: Quality\r
│   ├── m3.xml\r
│   └── ...\r
├── m4/  # Module 4: Nonclinical Study Reports\r
│   ├── m4.xml\r
│   └── ...\r
├── m5/  # Module 5: Clinical Study Reports\r
│   ├── m5.xml\r
│   └── ...\r
├── index.xml      # Master index file\r
├── index-md5.txt  # MD5 checksum file\r
└── dtd/           # DTD files\r
```\r
\r
## Usage\r
\r
```text\r
python skills/ectd-xml-compiler/scripts/main.py [options] \x3Cinput_files...>\r
```\r
\r
### Arguments\r
\r
| Argument | Description |\r
|----------|-------------|\r
| `input_files` | Input Word/PDF file paths (supports multiple) |\r
\r
### Options\r
\r
| Option | Short | Description | Default |\r
|--------|-------|-------------|---------|\r
| `--output` | `-o` | Output directory path | `./ectd-output` |\r
| `--module` | `-m` | Target module (m1-m5, auto) | `auto` |\r
| `--region` | `-r` | Target region (FDA, EMA, ICH) | `ICH` |\r
| `--version` | `-v` | eCTD version (3.2.2, 4.0) | `4.0` |\r
| `--dtd-path` | `-d` | Custom DTD path | Built-in DTD |\r
| `--validate` |  | Validate generated XML | `False` |\r
\r
### Examples\r
\r
```text\r
\r
# Basic usage - auto-detect module\r
python skills/ectd-xml-compiler/scripts/main.py document1.docx document2.pdf\r
\r
# Specify output directory and module\r
python skills/ectd-xml-compiler/scripts/main.py -o ./my-ectd -m m3 quality-doc.docx\r
\r
# FDA submission format\r
python skills/ectd-xml-compiler/scripts/main.py -r FDA -v 3.2.2 *.pdf\r
\r
# Validate generated XML\r
python skills/ectd-xml-compiler/scripts/main.py --validate submission.pdf\r
```\r
\r
## Input Document Processing\r
\r
### Supported Formats\r
- Microsoft Word (.docx, .doc)\r
- PDF (.pdf)\r
\r
### Document Parsing Logic\r
1. **Title Recognition**: Extract heading hierarchy based on font size and style\r
2. **TOC Mapping**: Auto-recognize section numbers (e.g., 3.2.S.1.1)\r
3. **Metadata Extraction**: Extract author, date, version, and other information\r
4. **Content Classification**: Map to corresponding eCTD modules based on keyword matching\r
\r
### Module Auto-Recognition Rules\r
\r
| Keyword Pattern | Target Module |\r
|------------|----------|\r
| Administrative, Label, Package Insert | m1 |\r
| Summary, summary, Overview | m2 |\r
| Quality, quality, CMC, API, Drug Product | m3 |\r
| Nonclinical, Toxicology, Pharmacokinetics | m4 |\r
| Clinical, clinical, Study, Trial | m5 |\r
\r
## Output Structure\r
\r
Generated eCTD skeleton contains:\r
\r
### index.xml\r
Master index file containing references and sequence information for all modules.\r
\r
### Module XML (m1.xml - m5.xml)\r
XML skeleton for each module, containing:\r
- Document hierarchy structure (`\x3Cleaf>`, `\x3Cnode>`)\r
- Cross-references (`\x3Ccross-reference>`)\r
- Attribute definitions (ID, version, operation type)\r
\r
### MD5 Checksums\r
MD5 checksum values for each file to ensure integrity.\r
\r
## Installation\r
\r
```text\r
\r
# Install dependencies\r
pip install python-docx PyPDF2 lxml\r
```\r
\r
## Validation\r
\r
Using `--validate` option can validate generated XML:\r
- DTD structure validation\r
- Required elements and attributes check\r
- Cross-reference integrity check\r
\r
## References\r
\r
- [ICH eCTD Specification v4.0](https://www.ich.org/page/ectd)\r
- [FDA eCTD Guidance](https://www.fda.gov/drugs/electronic-regulatory-submission-and-review/ectd-technical-conformance-guide)\r
- [EMA eCTD Requirements](https://www.ema.europa.eu/en/human-regulatory/marketing-authorisation/application-procedures/electronic-application-forms)\r
\r
## License\r
\r
MIT License\r
\r
## Risk Assessment\r
\r
| Risk Indicator | Assessment | Level |\r
|----------------|------------|-------|\r
| Code Execution | Python/R scripts executed locally | Medium |\r
| Network Access | No external API calls | Low |\r
| File System Access | Read input files, write output files | Medium |\r
| Instruction Tampering | Standard prompt guidelines | Low |\r
| Data Exposure | Output files saved to workspace | Low |\r
\r
## Security Checklist\r
\r
- [ ] No hardcoded credentials or API keys\r
- [ ] No unauthorized file system access (../)\r
- [ ] Output does not expose sensitive information\r
- [ ] Prompt injection protections in place\r
- [ ] Input file paths validated (no ../ traversal)\r
- [ ] Output directory restricted to workspace\r
- [ ] Script execution in sandboxed environment\r
- [ ] Error messages sanitized (no stack traces exposed)\r
- [ ] Dependencies audited\r
\r
## Prerequisites\r
\r
No additional Python packages required.\r
\r
## Evaluation Criteria\r
\r
### Success Metrics\r
- [ ] Successfully executes main functionality\r
- [ ] Output meets quality standards\r
- [ ] Handles edge cases gracefully\r
- [ ] Performance is acceptable\r
\r
### Test Cases\r
1. **Basic Functionality**: Standard input → Expected output\r
2. **Edge Case**: Invalid input → Graceful error handling\r
3. **Performance**: Large dataset → Acceptable processing time\r
\r
## Lifecycle Status\r
\r
- **Current Stage**: Draft\r
- **Next Review Date**: 2026-03-06\r
- **Known Issues**: None\r
- **Planned Improvements**: \r
  - Performance optimization\r
  - Additional feature support\r
\r
## Output Requirements\r
\r
Every final response should make these items explicit when they are relevant:\r
\r
- Objective or requested deliverable\r
- Inputs used and assumptions introduced\r
- Workflow or decision path\r
- Core result, recommendation, or artifact\r
- Constraints, risks, caveats, or validation needs\r
- Unresolved items and next-step checks\r
\r
## Error Handling\r
\r
- If required inputs are missing, state exactly which fields are missing and request only the minimum additional information.\r
- If the task goes outside the documented scope, stop instead of guessing or silently widening the assignment.\r
- If `scripts/main.py` fails, report the failure point, summarize what still can be completed safely, and provide a manual fallback.\r
- Do not fabricate files, citations, data, search results, or execution outcomes.\r
\r
## Input Validation\r
\r
This skill accepts requests that match the documented purpose of `ectd-xml-compiler` and include enough context to complete the workflow safely.\r
\r
Do not continue the workflow when the request is out of scope, missing a critical input, or would require unsupported assumptions. Instead respond:\r
\r
> `ectd-xml-compiler` only handles its documented workflow. Please provide the missing required inputs or switch to a more suitable skill.\r
\r
## References\r
\r
- [references/audit-reference.md](references/audit-reference.md) - Supported scope, audit commands, and fallback boundaries\r
\r
## Response Template\r
\r
Use the following fixed structure for non-trivial requests:\r
\r
1. Objective\r
2. Inputs Received\r
3. Assumptions\r
4. Workflow\r
5. Deliverable\r
6. Risks and Limits\r
7. Next Checks\r
\r
If the request is simple, you may compress the structure, but still keep assumptions and limits explicit when they affect correctness.\r
Usage Guidance
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.
Capability Analysis
Type: OpenClaw Skill Name: ectd-xml-compiler Version: 1.0.0 The skill is a legitimate utility for converting pharmaceutical regulatory documents (Word/PDF) into eCTD XML structures. The core logic in `scripts/main.py` uses standard libraries like `python-docx` and `PyPDF2` for parsing and `xml.etree` for generation, with no evidence of network exfiltration, unauthorized file access, or malicious execution. While there is a minor coding error in the directory path logic within `_generate_module_xml`, it appears to be an unintentional bug rather than a security flaw or malicious intent.
Capability Assessment
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.
How to Use
  1. Make sure OpenClaw is installed (local or Docker)
  2. Run the install command in chat: /install ectd-xml-compiler
  3. After installation, invoke the skill by name or use /ectd-xml-compiler
  4. Provide required inputs per the skill's parameter spec and get structured output
Version History
v1.0.0
eCTD XML Compiler 1.0.0 – Initial Release - Converts uploaded drug application documents (Word/PDF) into XML skeletons compliant with eCTD 4.0/3.2.2. - Supports module auto-recognition and mapping to m1–m5 based on content. - Includes a command-line interface with options for output path, module, region, and validation. - Extracts document hierarchy, metadata, and generates master index and per-module XML files with MD5 checksums. - Provides sample commands, reference materials, and workflow guidance for consistent execution.
Metadata
Slug ectd-xml-compiler
Version 1.0.0
License MIT-0
All-time Installs 0
Active Installs 0
Total Versions 1
Frequently Asked Questions

What is eCTD XML Compiler?

Automatically convert uploaded drug application documents (Word/PDF) into XML skeleton structure compliant with eCTD 4.0/3.2.2 specifications. It is an AI Agent Skill for Claude Code / OpenClaw, with 90 downloads so far.

How do I install eCTD XML Compiler?

Run "/install ectd-xml-compiler" in the OpenClaw or Claude Code chat to install it in one step — no extra setup required.

Is eCTD XML Compiler free?

Yes, eCTD XML Compiler is completely free, licensed under MIT-0. You can download, install and use it at no cost.

Which platforms does eCTD XML Compiler support?

eCTD XML Compiler is cross-platform and runs anywhere OpenClaw / Claude Code is available (cross-platform).

Who created eCTD XML Compiler?

It is built and maintained by AIpoch (@aipoch-ai); the current version is v1.0.0.

💬 Comments