diff --git a/README.md b/README.md
index f47ad33..310507f 100644
--- a/README.md
+++ b/README.md
@@ -1,10 +1,10 @@
+
-
+![readme-try-prisma](https://user-images.githubusercontent.com/18456526/202004157-e7c97399-1669-4d80-899c-537e09758214.png)
+
+[![Tests](https://github.com/prisma/try-prisma/actions/workflows/test.yml/badge.svg)](https://github.com/prisma/try-prisma/actions/workflows/test.yml)
+[![Linting](https://github.com/prisma/try-prisma/actions/workflows/lint.yml/badge.svg)](https://github.com/prisma/try-prisma/actions/workflows/lint.yml)
- ![readme-try-prisma](https://user-images.githubusercontent.com/18456526/202004157-e7c97399-1669-4d80-899c-537e09758214.png)
-
- [![Tests](https://github.com/prisma/try-prisma/actions/workflows/test.yml/badge.svg)](https://github.com/prisma/try-prisma/actions/workflows/test.yml)
- [![Linting](https://github.com/prisma/try-prisma/actions/workflows/lint.yml/badge.svg)](https://github.com/prisma/try-prisma/actions/workflows/lint.yml)
`try-prisma` is a CLI tool that helps you easily get up and running with any project from the [`prisma/prisma-examples`](https://github.com/prisma/prisma-examples) repository.
@@ -29,12 +29,13 @@ You can _optionally_ provide arguments to the `npx try-prisma` command as an alt
The options are as follows:
-| Option | Alias | Arguments | Default | Description |
-| :----------: | :---: | :------------------: | :-------------------: | ------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
-| `--install` | -i | Boolean | String _(optional)_ | `false` | Specifies if you would like to install npm packages automatically after creating the project. You can also specify which package manager to use: `npm`, `yarn`, or `pnpm` |
-| `--name` | -n | | Name of the selected template | Defines the name of the resulting directory. |
-| `--template` | -t | | n/a | Specifies which example project you would like to start off with. |
-| `--vscode` | -v | Boolean _(optional)_ | `false` | Adds a `.vscode` folder with an `extensions.json` file suggesting the [Prisma VS Code extension](https://marketplace.visualstudio.com/items?itemName=Prisma.prisma). |
+| Option | Alias | Arguments | Default | Description |
+| :--------------: | :---: | :------------------: | :---------------------------: | -------------------------------------------------------------------------------------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
+| `--install` | -i | Boolean | `false` | | Specifies if you would like to install npm packages automatically after creating the project. You can also specify which package manager to use: `npm`, `yarn`, or `pnpm` |
+| `--name` | -n | | Name of the selected template | Defines the name of the resulting directory. |
+| `--template` | -t | | n/a | Specifies which example project you would like to start off with. |
+| `--database-url` | -d | | n/a | Specifies the database URL you would like to use for the project. |
+| `--vscode` | -v | Boolean _(optional)_ | `false` | Adds a `.vscode` folder with an `extensions.json` file suggesting the [Prisma VS Code extension](https://marketplace.visualstudio.com/items?itemName=Prisma.prisma). |
## Examples
@@ -70,4 +71,4 @@ Interactive terminal who?? Use all the options!
```npx
npx try-prisma -t orm/grpc -i pnpm -n my_project
-```
\ No newline at end of file
+```
diff --git a/package.json b/package.json
index f22a2cd..66a5a2d 100644
--- a/package.json
+++ b/package.json
@@ -1,6 +1,6 @@
{
"name": "try-prisma",
- "version": "1.0.56",
+ "version": "1.0.57",
"description": "A CLI tool to help get you up and running with any Prisma example project.",
"type": "module",
"exports": "./dist/index.js",
diff --git a/src/cli/parameters.ts b/src/cli/parameters.ts
index 1834af3..59ba8c3 100644
--- a/src/cli/parameters.ts
+++ b/src/cli/parameters.ts
@@ -20,4 +20,5 @@ export default {
.default(false)
.describe("Should this invocation be recorded with Prisma's analytics?"),
"v vscode": z.boolean().default(false).describe("Are you using VSCode?"),
+ "d database-url": z.string().default("").describe("Provide a database URL to the template if desired."),
};
diff --git a/src/index.ts b/src/index.ts
index d871945..59ab831 100644
--- a/src/index.ts
+++ b/src/index.ts
@@ -1,4 +1,6 @@
#!/usr/bin/env node
+import fs from "node:fs"
+
import CLI from "./cli";
import download from "./helpers/download";
import installPackages from "./helpers/installPackages";
@@ -58,6 +60,16 @@ const main = async () => {
}
}
+ if (input.databaseUrl) {
+ fs.writeFileSync(`${input.path}/${input.name}/.env`, `DATABASE_URL="${input.databaseUrl}"\n`, { flag: "a" })
+ if (input.databaseUrl.startsWith("prisma://")) {
+ const queryParams = input.databaseUrl.split("?")[1]
+ const urlParams = new URLSearchParams(queryParams)
+ const apiKey = urlParams.get("api_key")
+ fs.writeFileSync(`${input.path}/${input.name}/.env`, `PULSE_API_KEY="${apiKey}"\n`, { flag: "a" })
+ }
+ }
+
if (input.vscode) {
await vscodeExtensionSuggestion(input);
}
diff --git a/src/types.ts b/src/types.ts
index 959202b..7149af7 100644
--- a/src/types.ts
+++ b/src/types.ts
@@ -7,4 +7,5 @@ export type CliInput = {
vscode: boolean;
path: string;
folder: string;
+ databaseUrl: string;
};
diff --git a/test/cli/input-collector.test.ts b/test/cli/input-collector.test.ts
index d6b1982..484c4d8 100644
--- a/test/cli/input-collector.test.ts
+++ b/test/cli/input-collector.test.ts
@@ -50,6 +50,7 @@ describe("Input Collector", () => {
folder: "orm",
path: ".",
anonymous: false,
+ databaseUrl: "",
vscode: false,
});
});