{"id":13539942,"url":"https://github.com/medplum/medplum","last_synced_at":"2026-04-01T20:49:30.830Z","repository":{"id":37518993,"uuid":"360238600","full_name":"medplum/medplum","owner":"medplum","description":"Medplum is a healthcare platform that helps you quickly develop high-quality compliant applications.","archived":false,"fork":false,"pushed_at":"2026-01-24T01:08:10.000Z","size":343255,"stargazers_count":2103,"open_issues_count":553,"forks_count":671,"subscribers_count":17,"default_branch":"main","last_synced_at":"2026-01-24T08:58:45.814Z","etag":null,"topics":["ehr","electronic-health-record","fhir","fhir-server","graphql","healthcare","hipaa","medical","react","soc2","typescript"],"latest_commit_sha":null,"homepage":"https://medplum.com","language":"TypeScript","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"apache-2.0","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/medplum.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":"LICENSE.txt","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":".github/CODEOWNERS","security":"SECURITY.md","support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null,"zenodo":null,"notice":"NOTICE","maintainers":null,"copyright":null,"agents":null,"dco":null,"cla":null}},"created_at":"2021-04-21T16:36:22.000Z","updated_at":"2026-01-24T00:10:45.000Z","dependencies_parsed_at":"2023-10-17T01:30:57.252Z","dependency_job_id":"180c66e7-1175-43d0-bd7f-f46dc9b21370","html_url":"https://github.com/medplum/medplum","commit_stats":{"total_commits":4003,"total_committers":112,"mean_commits":35.74107142857143,"dds":"0.42368223832125906","last_synced_commit":"4cec0e5adeb943a188c0e6c7ec779a6618caae1b"},"previous_names":[],"tags_count":265,"template":false,"template_full_name":null,"purl":"pkg:github/medplum/medplum","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/medplum%2Fmedplum","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/medplum%2Fmedplum/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/medplum%2Fmedplum/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/medplum%2Fmedplum/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/medplum","download_url":"https://codeload.github.com/medplum/medplum/tar.gz/refs/heads/main","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/medplum%2Fmedplum/sbom","scorecard":{"id":496949,"data":{"date":"2025-08-18T23:57:33Z","repo":{"name":"github.com/medplum/medplum","commit":"179369b2fa11720185210243927c1e3c04b2798d"},"scorecard":{"version":"v5.1.1","commit":"cd152cb6742c5b8f2f3d2b5193b41d9c50905198"},"score":7.3,"checks":[{"name":"Maintained","score":10,"reason":"30 commit(s) and 14 issue activity found in the last 90 days -- score normalized to 10","details":null,"documentation":{"short":"Determines if the project is \"actively maintained\".","url":"https://github.com/ossf/scorecard/blob/cd152cb6742c5b8f2f3d2b5193b41d9c50905198/docs/checks.md#maintained"}},{"name":"Code-Review","score":10,"reason":"all changesets reviewed","details":null,"documentation":{"short":"Determines if the project requires human code review before pull requests (aka merge requests) are merged.","url":"https://github.com/ossf/scorecard/blob/cd152cb6742c5b8f2f3d2b5193b41d9c50905198/docs/checks.md#code-review"}},{"name":"Packaging","score":-1,"reason":"packaging workflow not detected","details":["Warn: no GitHub/GitLab publishing workflow detected."],"documentation":{"short":"Determines if the project is published as a package that others can easily download, install, easily update, and uninstall.","url":"https://github.com/ossf/scorecard/blob/cd152cb6742c5b8f2f3d2b5193b41d9c50905198/docs/checks.md#packaging"}},{"name":"Security-Policy","score":10,"reason":"security policy file detected","details":["Info: security policy file detected: SECURITY.md:1","Info: Found linked content: SECURITY.md:1","Info: Found disclosure, vulnerability, and/or timelines in security policy: SECURITY.md:1","Info: Found text in security policy: SECURITY.md:1"],"documentation":{"short":"Determines if the project has published a security policy.","url":"https://github.com/ossf/scorecard/blob/cd152cb6742c5b8f2f3d2b5193b41d9c50905198/docs/checks.md#security-policy"}},{"name":"Dangerous-Workflow","score":0,"reason":"dangerous workflow patterns detected","details":["Warn: untrusted code checkout '${{ github.event.workflow_run.head_branch }}': .github/workflows/coveralls.yml:18","Warn: untrusted code checkout '${{ github.event.workflow_run.head_branch }}': .github/workflows/sonar.yml:19"],"documentation":{"short":"Determines if the project's GitHub Action workflows avoid dangerous patterns.","url":"https://github.com/ossf/scorecard/blob/cd152cb6742c5b8f2f3d2b5193b41d9c50905198/docs/checks.md#dangerous-workflow"}},{"name":"Token-Permissions","score":10,"reason":"GitHub workflow tokens follow principle of least privilege","details":["Warn: jobLevel 'contents' permission set to 'write': .github/workflows/autofix-ci.yml:21","Info: jobLevel 'actions' permission set to 'read': .github/workflows/build-agent.yml:22","Warn: jobLevel 'contents' permission set to 'write': .github/workflows/build-agent.yml:23","Info: jobLevel 'actions' permission set to 'read': .github/workflows/build-agent.yml:146","Warn: jobLevel 'contents' permission set to 'write': .github/workflows/build-agent.yml:147","Info: jobLevel 'actions' permission set to 'read': .github/workflows/build-agent.yml:220","Warn: jobLevel 'contents' permission set to 'write': .github/workflows/build-agent.yml:221","Info: jobLevel 'actions' permission set to 'read': .github/workflows/build-deb.yml:26","Warn: jobLevel 'contents' permission set to 'write': .github/workflows/build-deb.yml:27","Warn: jobLevel 'contents' permission set to 'write': .github/workflows/chromatic.yml:13","Warn: jobLevel 'contents' permission set to 'write': .github/workflows/claude.yml:25","Info: jobLevel 'actions' permission set to 'read': .github/workflows/codeql-analysis.yml:37","Info: jobLevel 'contents' permission set to 'read': .github/workflows/codeql-analysis.yml:38","Info: jobLevel 'actions' permission set to 'read': .github/workflows/publish.yml:25","Warn: jobLevel 'contents' permission set to 'write': .github/workflows/publish.yml:26","Warn: jobLevel 'contents' permission set to 'write': .github/workflows/publish.yml:116","Info: jobLevel 'actions' permission set to 'read': .github/workflows/publish.yml:115","Info: jobLevel 'actions' permission set to 'read': .github/workflows/publish.yml:271","Warn: jobLevel 'contents' permission set to 'write': .github/workflows/publish.yml:272","Info: topLevel 'contents' permission set to 'read': .github/workflows/add-issue-to-project.yml:12","Info: topLevel 'contents' permission set to 'read': .github/workflows/assign-pull-request.yml:8","Info: topLevel 'contents' permission set to 'read': .github/workflows/autofix-ci.yml:15","Info: topLevel 'contents' permission set to 'read': .github/workflows/build-agent.yml:10","Info: topLevel 'contents' permission set to 'read': .github/workflows/build-deb.yml:14","Info: topLevel 'contents' permission set to 'read': .github/workflows/build-helm-charts.yml:14","Info: topLevel 'contents' permission set to 'read': .github/workflows/build.yml:15","Info: topLevel 'contents' permission set to 'read': .github/workflows/chromatic.yml:6","Info: topLevel 'contents' permission set to 'read': .github/workflows/claude.yml:14","Info: topLevel 'contents' permission set to 'read': .github/workflows/codeql-analysis.yml:30","Info: topLevel 'contents' permission set to 'read': .github/workflows/coveralls.yml:8","Info: topLevel 'contents' permission set to 'read': .github/workflows/deploy.yml:13","Info: topLevel 'contents' permission set to 'read': .github/workflows/labeler.yml:6","Info: topLevel 'contents' permission set to 'read': .github/workflows/madge.yml:13","Info: topLevel 'contents' permission set to 'read': .github/workflows/prepare-release.yml:11","Info: topLevel 'contents' permission set to 'read': .github/workflows/publish-meta.yml:13","Info: topLevel 'contents' permission set to 'read': .github/workflows/publish.yml:10","Info: topLevel permissions set to 'read-all': .github/workflows/scorecard.yml:20","Info: topLevel 'contents' permission set to 'read': .github/workflows/sonar.yml:8","Info: topLevel 'contents' permission set to 'read': .github/workflows/staging.yml:10","Info: topLevel 'contents' permission set to 'read': .github/workflows/upgrade-dependencies.yml:16"],"documentation":{"short":"Determines if the project's workflows follow the principle of least privilege.","url":"https://github.com/ossf/scorecard/blob/cd152cb6742c5b8f2f3d2b5193b41d9c50905198/docs/checks.md#token-permissions"}},{"name":"Binary-Artifacts","score":10,"reason":"no binaries found in the repo","details":null,"documentation":{"short":"Determines if the project has generated executable (binary) artifacts in the source repository.","url":"https://github.com/ossf/scorecard/blob/cd152cb6742c5b8f2f3d2b5193b41d9c50905198/docs/checks.md#binary-artifacts"}},{"name":"CII-Best-Practices","score":10,"reason":"badge detected: Gold","details":null,"documentation":{"short":"Determines if the project has an OpenSSF (formerly CII) Best Practices Badge.","url":"https://github.com/ossf/scorecard/blob/cd152cb6742c5b8f2f3d2b5193b41d9c50905198/docs/checks.md#cii-best-practices"}},{"name":"Fuzzing","score":0,"reason":"project is not fuzzed","details":["Warn: no fuzzer integrations found"],"documentation":{"short":"Determines if the project uses fuzzing.","url":"https://github.com/ossf/scorecard/blob/cd152cb6742c5b8f2f3d2b5193b41d9c50905198/docs/checks.md#fuzzing"}},{"name":"Pinned-Dependencies","score":8,"reason":"dependency not pinned by hash detected -- score normalized to 8","details":["Warn: third-party GitHubAction not pinned by hash: .github/workflows/build-deb.yml:56: update your workflow using https://app.stepsecurity.io/secureworkflow/medplum/medplum/build-deb.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/publish.yml:284: update your workflow using https://app.stepsecurity.io/secureworkflow/medplum/medplum/publish.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/publish.yml:40: update your workflow using https://app.stepsecurity.io/secureworkflow/medplum/medplum/publish.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/publish.yml:52: update your workflow using https://app.stepsecurity.io/secureworkflow/medplum/medplum/publish.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/publish.yml:79: update your workflow using https://app.stepsecurity.io/secureworkflow/medplum/medplum/publish.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/publish.yml:85: update your workflow using https://app.stepsecurity.io/secureworkflow/medplum/medplum/publish.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/publish.yml:128: update your workflow using https://app.stepsecurity.io/secureworkflow/medplum/medplum/publish.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/publish.yml:146: update your workflow using https://app.stepsecurity.io/secureworkflow/medplum/medplum/publish.yml/main?enable=pin","Warn: containerImage not pinned by hash: Dockerfile:14: pin your Docker image by updating node:20-slim to node:20-slim@sha256:6db5e436948af8f0244488a1f658c2c8e55a3ae51ca2e1686ed042be8f25f70a","Warn: containerImage not pinned by hash: packages/agent/Dockerfile:1: pin your Docker image by updating debian:bullseye-slim to debian:bullseye-slim@sha256:849d9d34d5fe0bf88b5fb3d09eb9684909ac4210488b52f4f7bbe683eedcb851","Warn: containerImage not pinned by hash: packages/app/Dockerfile:1: pin your Docker image by updating nginxinc/nginx-unprivileged:alpine to nginxinc/nginx-unprivileged:alpine@sha256:5fed1af03cc6e82fe276efec6fbfc6c5659d42b4e6f1f45ddccd2758f8c1d8ab","Warn: downloadThenRun not pinned by hash: scripts/build-agent-installer-win64.sh:89","Warn: downloadThenRun not pinned by hash: scripts/build-agent-installer-win64.sh:110","Warn: npmCommand not pinned by hash: scripts/deploy-bot-layer.sh:33","Warn: npmCommand not pinned by hash: scripts/reinstall.sh:26","Warn: npmCommand not pinned by hash: .github/workflows/madge.yml:51","Info:  74 out of  78 GitHub-owned GitHubAction dependencies pinned","Info:  20 out of  24 third-party GitHubAction dependencies pinned","Info:  18 out of  21 npmCommand dependencies pinned","Info:   0 out of   2 downloadThenRun dependencies pinned","Info:   0 out of   3 containerImage dependencies pinned"],"documentation":{"short":"Determines if the project has declared and pinned the dependencies of its build process.","url":"https://github.com/ossf/scorecard/blob/cd152cb6742c5b8f2f3d2b5193b41d9c50905198/docs/checks.md#pinned-dependencies"}},{"name":"License","score":10,"reason":"license file detected","details":["Info: project has a license file: LICENSE.txt:0","Info: FSF or OSI recognized license: Apache License 2.0: LICENSE.txt:0"],"documentation":{"short":"Determines if the project has defined a license.","url":"https://github.com/ossf/scorecard/blob/cd152cb6742c5b8f2f3d2b5193b41d9c50905198/docs/checks.md#license"}},{"name":"SAST","score":10,"reason":"SAST tool is run on all commits","details":["Info: SAST configuration detected: CodeQL","Info: all commits (30) are checked with a SAST tool"],"documentation":{"short":"Determines if the project uses static code analysis.","url":"https://github.com/ossf/scorecard/blob/cd152cb6742c5b8f2f3d2b5193b41d9c50905198/docs/checks.md#sast"}},{"name":"Dependency-Update-Tool","score":10,"reason":"update tool detected","details":["Info: detected update tool: Dependabot: :0"],"documentation":{"short":"Determines if the project uses a dependency update tool.","url":"https://github.com/ossf/scorecard/blob/cd152cb6742c5b8f2f3d2b5193b41d9c50905198/docs/checks.md#dependency-update-tool"}},{"name":"Signed-Releases","score":0,"reason":"Project has not signed or included provenance with any releases.","details":["Warn: release artifact v4.3.10 not signed: https://api.github.com/repos/medplum/medplum/releases/239518803","Warn: release artifact v4.3.9 not signed: https://api.github.com/repos/medplum/medplum/releases/238678608","Warn: release artifact v4.3.8 not signed: https://api.github.com/repos/medplum/medplum/releases/237504851","Warn: release artifact v4.3.7 not signed: https://api.github.com/repos/medplum/medplum/releases/236428577","Warn: release artifact v4.3.6 not signed: https://api.github.com/repos/medplum/medplum/releases/233002502","Warn: release artifact v4.3.10 does not have provenance: https://api.github.com/repos/medplum/medplum/releases/239518803","Warn: release artifact v4.3.9 does not have provenance: https://api.github.com/repos/medplum/medplum/releases/238678608","Warn: release artifact v4.3.8 does not have provenance: https://api.github.com/repos/medplum/medplum/releases/237504851","Warn: release artifact v4.3.7 does not have provenance: https://api.github.com/repos/medplum/medplum/releases/236428577","Warn: release artifact v4.3.6 does not have provenance: https://api.github.com/repos/medplum/medplum/releases/233002502"],"documentation":{"short":"Determines if the project cryptographically signs release artifacts.","url":"https://github.com/ossf/scorecard/blob/cd152cb6742c5b8f2f3d2b5193b41d9c50905198/docs/checks.md#signed-releases"}},{"name":"Branch-Protection","score":-1,"reason":"internal error: error during branchesHandler.setup: internal error: githubv4.Query: Resource not accessible by integration","details":null,"documentation":{"short":"Determines if the default and release branches are protected with GitHub's branch protection settings.","url":"https://github.com/ossf/scorecard/blob/cd152cb6742c5b8f2f3d2b5193b41d9c50905198/docs/checks.md#branch-protection"}},{"name":"CI-Tests","score":10,"reason":"30 out of 30 merged PRs checked by a CI test -- score normalized to 10","details":null,"documentation":{"short":"Determines if the project runs tests before pull requests are merged.","url":"https://github.com/ossf/scorecard/blob/cd152cb6742c5b8f2f3d2b5193b41d9c50905198/docs/checks.md#ci-tests"}},{"name":"Contributors","score":10,"reason":"project has 7 contributing companies or organizations","details":["Info: found contributions from: ElektraLabs, flexpa, medplum, numenta, self, vinta software studio, vintasoftware"],"documentation":{"short":"Determines if the project has a set of contributors from multiple organizations (e.g., companies).","url":"https://github.com/ossf/scorecard/blob/cd152cb6742c5b8f2f3d2b5193b41d9c50905198/docs/checks.md#contributors"}},{"name":"Vulnerabilities","score":8,"reason":"2 existing vulnerabilities detected","details":["Warn: Project is vulnerable to: GHSA-4v9v-hfq4-rm2v","Warn: Project is vulnerable to: GHSA-9jgg-88mc-972h"],"documentation":{"short":"Determines if the project has open, known unfixed vulnerabilities.","url":"https://github.com/ossf/scorecard/blob/cd152cb6742c5b8f2f3d2b5193b41d9c50905198/docs/checks.md#vulnerabilities"}}]},"last_synced_at":"2025-08-19T20:39:51.428Z","repository_id":37518993,"created_at":"2025-08-19T20:39:51.428Z","updated_at":"2025-08-19T20:39:51.428Z"},"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":286080680,"owners_count":28854404,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2026-01-28T22:56:21.783Z","status":"ssl_error","status_checked_at":"2026-01-28T22:56:00.861Z","response_time":57,"last_error":"SSL_connect returned=1 errno=0 peeraddr=140.82.121.6:443 state=error: unexpected eof while reading","robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":false,"can_crawl_api":true,"host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["ehr","electronic-health-record","fhir","fhir-server","graphql","healthcare","hipaa","medical","react","soc2","typescript"],"created_at":"2024-08-01T09:01:34.862Z","updated_at":"2026-02-28T08:45:03.282Z","avatar_url":"https://github.com/medplum.png","language":"TypeScript","funding_links":[],"categories":["TypeScript","Data Standards \u0026 Interoperability","typescript","Fullstack Examples","\u003ca name=\"TypeScript\"\u003e\u003c/a\u003eTypeScript"],"sub_categories":["FHIR Servers"],"readme":"# [Medplum](https://www.medplum.com) \u0026middot; [![GitHub license](https://img.shields.io/badge/license-Apache-blue.svg)](https://github.com/medplum/medplum/blob/main/LICENSE.txt) [![npm version](https://img.shields.io/npm/v/@medplum/core.svg?color=blue)](https://www.npmjs.com/package/@medplum/core) [![Quality Gate Status](https://sonarcloud.io/api/project_badges/measure?project=medplum_medplum\u0026metric=alert_status\u0026token=207c95a43e7519809d6d336d8cc7837d3e057acf)](https://sonarcloud.io/dashboard?id=medplum_medplum) [![Coverage Status](https://coveralls.io/repos/github/medplum/medplum/badge.svg?branch=main)](https://coveralls.io/github/medplum/medplum?branch=main) [![OpenSSF Best Practices](https://www.bestpractices.dev/projects/10900/badge?gold)](https://www.bestpractices.dev/projects/10900)\n\n![Medplum](packages/docs/static/img/cover.webp)\n\nMedplum is a developer platform that enables flexible and rapid development of healthcare apps.\n\n- **Medplum Auth** - End-to-end identity solution for easy user authentication, sign-in, and permissions using OAuth, OpenID, and SMART-on-FHIR.\n- **Medplum Clinical Data Repository (CDR)** - Backend server that hosts your healthcare data in a secure, compliant, and standards-based repository.\n- **Medplum API** - FHIR-based API for sending, receiving, and manipulating data.\n- **Medplum SDK** - Client libraries that simplify the process of interacting with the **Medplum API**.\n- **Medplum App** - Web application where you can view your data and perform basic editing tasks. You can also use the Medplum App to manage basic workflows.\n- **Medplum Bots** - Write and run application logic server-side without needing to set up your own server.\n- **UI Component Library** - React components designed to help you quickly develop custom healthcare applications.\n\n## Docs\n\n- [Contributing](#contributing)\n  - [Ground Rules](#ground-rules)\n  - [Codebase](#codebase)\n    - [Technologies](#technologies)\n    - [Folder Structure](#folder-structure)\n\n## Contributing\n\n**We heartily welcome any and all contributions that match our engineering standards!**\n\nThat being said, this codebase isn't your typical open-source project because it's not a library or package with a\nlimited scope -- it's our entire product. Our [Contributing documentation](https://medplum.com/docs/contributing) has\nall the information you need to get started.\n\n### Ground Rules\n\n#### Contributions and discussion guidelines\n\nBy making a contribution to this project, you are deemed to have accepted the [Developer Certificate of Origin](https://developercertificate.org/) (DCO).\n\nAll conversations and communities on Medplum are expected to follow GitHub's [Community Guidelines](https://help.github.com/en/github/site-policy/github-community-guidelines)\nand [Acceptable Use Policies](https://help.github.com/en/github/site-policy/github-acceptable-use-policies). We expect\ndiscussions on issues and pull requests to stay positive, productive, and respectful. Remember: there are real people on\nthe other side of the screen!\n\n#### Reporting a bug or proposing a new feature\n\nIf you found a technical bug on Medplum or have ideas for features we should implement, the issue tracker is the best\nplace to share with us. ([click here to open a new issue](https://github.com/medplum/medplum/issues/new))\n\n### Writing documentation or blog content\n\nDid you learn how to do something using Medplum that wasn't obvious on your first try? By contributing your new knowledge\nto our documentation, you can help others who might have a similar use case!\n\nOur documentation is hosted on [medplum.com/docs](https://www.medplum.com/docs), but it is built from [Markdown](https://www.markdownguide.org/)\nfiles in our [`docs` package](https://github.com/medplum/medplum/tree/main/packages/docs/docs).\n\nFor relatively small changes, you can edit files directly from your web browser on [Github.dev](https://github.dev/medplum/medplum/blob/main/packages/docs/docs/home.md)\nwithout needing to clone the repository.\n\n#### Fixing a bug or implementing a new feature\n\nIf you find a bug and open a Pull Request that fixes it, we'll review it as soon as possible to ensure it meets our engineering standards.\n\nIf you want to implement a new feature, open an issue first to discuss with us how the feature might work, and to ensure\nit fits into our roadmap and plans for the app.\n\nIf you want to contribute but are unsure how to start, we have [a \"good first issue\" label](https://github.com/medplum/medplum/issues?q=is%3Aissue+is%3Aopen+label%3A%22good+first+issue%22) which is applied to newcomer-friendly issues. Take a look at [the full list of good first issues](https://github.com/medplum/medplum/issues?q=is%3Aissue+is%3Aopen+label%3A%22good+first+issue%22) and pick something you like!\n\n**Ready to get started writing code?** Follow the [local setup instructions](https://www.medplum.com/docs/contributing/local-dev-setup) and jump in!\n\n### Codebase\n\n#### Technologies\n\nWith the ground rules out of the way, let's talk about the coarse architecture of this mono repo:\n\n- **Full-stack TypeScript**: We use Node.js to power our servers, and React to power our frontend apps. Almost all of the code you'll touch in this codebase will be TypeScript.\n\nHere is a list of all the big technologies we use:\n\n- **PostgreSQL**: Data storage\n- **Redis**: Background jobs and caching\n- **Express**: API server\n- **TypeScript**: Type-safe JavaScript\n- **React**: Frontend React app\n\n#### Folder structure\n\n```sh\nmedplum/\n├── packages\n│   ├── agent           # On-premise agent\n│   ├── app             # Frontend web app\n│   ├── bot-layer       # AWS Lambda Layer for Bots\n│   ├── cdk             # AWS CDK infra as code\n│   ├── cli             # Command line interface\n│   ├── core            # Core shared library\n│   ├── definitions     # Data definitions\n│   ├── docs            # Documentation\n│   ├── examples        # Example code used in documentation\n│   ├── fhir-router     # FHIR URL router\n│   ├── fhirtypes       # FHIR TypeScript definitions\n│   ├── generator       # Code generator utilities\n│   ├── graphiql        # Preconfigured GraphiQL\n│   ├── hl7             # HL7 client and server\n│   ├── mock            # Mock FHIR data for testing\n│   ├── react           # React component library\n│   ├── react-hooks     # React hooks library\n│   └── server          # Backend API server\n└── scripts             # Helper bash scripts\n```\n\n## Thanks\n\n\u003ca href=\"https://www.chromatic.com/\"\u003e\u003cimg src=\"https://user-images.githubusercontent.com/321738/84662277-e3db4f80-af1b-11ea-88f5-91d67a5e59f6.png\" width=\"153\" height=\"30\" alt=\"Chromatic\" /\u003e\u003c/a\u003e\n\nThanks to [Chromatic](https://www.chromatic.com/) for providing the visual testing platform that helps us review UI changes and catch visual regressions.\n\n## License\n\n[Apache 2.0](LICENSE.txt)\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fmedplum%2Fmedplum","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fmedplum%2Fmedplum","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fmedplum%2Fmedplum/lists"}