create-prisma-php-app 1.0.13 → 1.1.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.js CHANGED
@@ -1,2 +1,2 @@
1
1
  #!/usr/bin/env node
2
- import{execSync}from"child_process";import fs from"fs";import{fileURLToPath}from"url";import path from"path";import chalk from"chalk";import prompts from"prompts";const __filename=fileURLToPath(import.meta.url),__dirname=path.dirname(__filename);async function updatePackageJson(i){const t=path.join(i,"package.json"),e=JSON.parse(fs.readFileSync(t,"utf8"));e.scripts=Object.assign(Object.assign({},e.scripts),{postinstall:"prisma generate"}),e.type="module",e.prisma={seed:'ts-node --compiler-options {"module":"CommonJS"} prisma/seed.ts'},fs.writeFileSync(t,JSON.stringify(e,null,2))}async function createUpdateGitignoreFile(i,t){const e=path.join(i,".gitignore");let s="";fs.existsSync(e)&&(s=fs.readFileSync(e,"utf8")),t.forEach((i=>{s.includes(i)||(s+=`\n${i}`)})),s=s.trimStart(),fs.writeFileSync(e,s)}function copyRecursiveSync(i,t){const e=fs.existsSync(i),s=e&&fs.statSync(i);e&&s&&s.isDirectory()?(fs.mkdirSync(t,{recursive:!0}),fs.readdirSync(i).forEach((e=>copyRecursiveSync(path.join(i,e),path.join(t,e))))):fs.copyFileSync(i,t)}async function executeCopy(i,t){t.forEach((({srcDir:t,destDir:e})=>{copyRecursiveSync(path.join(__dirname,t),path.join(i,e))}))}function modifyTailwindConfig(i){const t=path.join(i,"tailwind.config.js");let e=fs.readFileSync(t,"utf8");const s=["./public/**/*.php","./public/**/*.html"].map((i=>` "${i}"`)).join(",\n");e=e.replace(/content: \[\],/g,`content: [\n${s}\n ],`),fs.writeFileSync(t,e,"utf8")}function modifyIndexPHP(i,t){const e=path.join(i,"public","index.php");try{let i=fs.readFileSync(e,"utf8");const s=t?' <link href="css/styles.css" rel="stylesheet"> \x3c!-- Stylesheet link to the tailwind compiled css --\x3e':' <script src="https://cdn.tailwindcss.com"><\/script>';i=i.replace("</head>",`${s}\n</head>`),fs.writeFileSync(e,i,"utf8")}catch(i){}}async function createDirectoryStructure(i,t){await updatePackageJson(i);const e=[{srcDir:"/settings",destDir:"/settings"},{srcDir:"/prisma",destDir:"/prisma"},{srcDir:"/src",destDir:"/src"},{srcDir:"/../vendor",destDir:"/vendor"}];t.tailwindcss&&e.push({srcDir:"/public/css/",destDir:"/public/css/"}),e.push({srcDir:"/public/assets/",destDir:"/public/assets/"}),await executeCopy(i,e),[{src:"/public/favicon.ico",dest:"/public/favicon.ico"},{src:"/public/index.php",dest:"/public/index.php"},{src:"/bootstrap.php",dest:"/bootstrap.php"},{src:"/../composer.json",dest:"/composer.json"},{src:"/../composer.lock",dest:"/composer.lock"}].forEach((({src:t,dest:e})=>{const s=path.join(__dirname,t),c=path.join(i,e),n=fs.readFileSync(s,"utf8");fs.writeFileSync(c,n)})),t.tailwindcss?(modifyTailwindConfig(i),modifyIndexPHP(i,!0)):modifyIndexPHP(i,!1)}async function getAnswer(){const i=[{type:"text",name:"projectName",message:"What is your project named?",initial:"my-app"},{type:"toggle",name:"tailwindcss",message:`Would you like to use ${chalk.blue("Tailwind CSS")}?`,initial:!0,active:"Yes",inactive:"No"}],t=()=>!1;try{const e=await prompts(i,{onCancel:t});return 0===Object.keys(e).length?null:{projectName:String(e.projectName).trim().replace(/ /g,"-"),tailwindcss:e.tailwindcss}}catch(i){return null}}async function installDependencies(i,t){execSync("npm init -y",{stdio:"inherit",cwd:i}),t.forEach((i=>{})),execSync(`npm install ${t.join(" ")}`,{stdio:"inherit",cwd:i})}async function main(){try{const i=await getAnswer();if(null===i)return;execSync("npm install -g create-prisma-php-app",{stdio:"inherit"}),fs.mkdirSync(i.projectName);const t=path.join(process.cwd(),i.projectName);process.chdir(i.projectName);const e=["prisma","@prisma/client","typescript","@types/node","ts-node"];i.tailwindcss&&e.push("tailwindcss","autoprefixer","postcss"),await installDependencies(t,e),execSync("npx prisma init",{stdio:"inherit"}),execSync("npx tsc --init",{stdio:"inherit"}),i.tailwindcss&&execSync("npx tailwindcss init -p",{stdio:"inherit"}),await createDirectoryStructure(t,i),i.tailwindcss&&execSync("npx tailwindcss -i ./public/css/tailwind.css -o ./public/css/styles.css --minify",{stdio:"inherit"});const s=path.join(t,"settings","project-settings.js"),c=`export const projectSettings = {\n PROJECT_NAME: "${i.projectName}",\n PROJECT_ROOT_PATH: "${t.replace(/\\/g,"\\\\")}",\n PHP_ROOT_PATH_EXE: "D:\\\\xampp\\\\php\\\\php.exe",\n PHP_GENERATE_CLASS_PATH: "src/app/classes/prisma",\n };`;fs.writeFileSync(s,c)}catch(i){process.exit(1)}}main();
2
+ import{execSync}from"child_process";import fs from"fs";import{fileURLToPath}from"url";import path from"path";import chalk from"chalk";import prompts from"prompts";const __filename=fileURLToPath(import.meta.url),__dirname=path.dirname(__filename);async function updatePackageJson(i){const t=path.join(i,"package.json"),e=JSON.parse(fs.readFileSync(t,"utf8"));e.scripts=Object.assign(Object.assign({},e.scripts),{postinstall:"prisma generate"}),e.type="module",e.prisma={seed:"node prisma/seed.js"},fs.writeFileSync(t,JSON.stringify(e,null,2))}async function createUpdateGitignoreFile(i,t){const e=path.join(i,".gitignore");let s="";fs.existsSync(e)&&(s=fs.readFileSync(e,"utf8")),t.forEach((i=>{s.includes(i)||(s+=`\n${i}`)})),s=s.trimStart(),fs.writeFileSync(e,s)}function copyRecursiveSync(i,t){const e=fs.existsSync(i),s=e&&fs.statSync(i);e&&s&&s.isDirectory()?(fs.mkdirSync(t,{recursive:!0}),fs.readdirSync(i).forEach((e=>copyRecursiveSync(path.join(i,e),path.join(t,e))))):fs.copyFileSync(i,t)}async function executeCopy(i,t){t.forEach((({srcDir:t,destDir:e})=>{copyRecursiveSync(path.join(__dirname,t),path.join(i,e))}))}function modifyTailwindConfig(i){const t=path.join(i,"tailwind.config.js");let e=fs.readFileSync(t,"utf8");const s=["./public/**/*.php","./public/**/*.html"].map((i=>` "${i}"`)).join(",\n");e=e.replace(/content: \[\],/g,`content: [\n${s}\n ],`),fs.writeFileSync(t,e,"utf8")}function modifyIndexPHP(i,t){const e=path.join(i,"public","index.php");try{let i=fs.readFileSync(e,"utf8");const s=t?' <link href="css/styles.css" rel="stylesheet"> \x3c!-- Stylesheet link to the tailwind compiled css --\x3e':' <script src="https://cdn.tailwindcss.com"><\/script>';i=i.replace("</head>",`${s}\n</head>`),fs.writeFileSync(e,i,"utf8")}catch(i){}}async function createDirectoryStructure(i,t){await updatePackageJson(i);const e=[{srcDir:"/settings",destDir:"/settings"},{srcDir:"/prisma",destDir:"/prisma"},{srcDir:"/src",destDir:"/src"},{srcDir:"/../vendor",destDir:"/vendor"}];t.tailwindcss&&e.push({srcDir:"/public/css/",destDir:"/public/css/"}),e.push({srcDir:"/public/assets/",destDir:"/public/assets/"}),await executeCopy(i,e),[{src:"/public/favicon.ico",dest:"/public/favicon.ico"},{src:"/public/index.php",dest:"/public/index.php"},{src:"/bootstrap.php",dest:"/bootstrap.php"},{src:"/../composer.json",dest:"/composer.json"},{src:"/../composer.lock",dest:"/composer.lock"}].forEach((({src:t,dest:e})=>{const s=path.join(__dirname,t),c=path.join(i,e),n=fs.readFileSync(s,"utf8");fs.writeFileSync(c,n)})),t.tailwindcss?(modifyTailwindConfig(i),modifyIndexPHP(i,!0)):modifyIndexPHP(i,!1)}async function getAnswer(){const i=[{type:"text",name:"projectName",message:"What is your project named?",initial:"my-app"},{type:"toggle",name:"tailwindcss",message:`Would you like to use ${chalk.blue("Tailwind CSS")}?`,initial:!0,active:"Yes",inactive:"No"}],t=()=>!1;try{const e=await prompts(i,{onCancel:t});return 0===Object.keys(e).length?null:{projectName:String(e.projectName).trim().replace(/ /g,"-"),tailwindcss:e.tailwindcss}}catch(i){return null}}async function installDependencies(i,t){execSync("npm init -y",{stdio:"inherit",cwd:i}),t.forEach((i=>{})),execSync(`npm install ${t.join(" ")}`,{stdio:"inherit",cwd:i})}async function main(){try{const i=await getAnswer();if(null===i)return;execSync("npm install -g create-prisma-php-app",{stdio:"inherit"}),fs.mkdirSync(i.projectName);const t=path.join(process.cwd(),i.projectName);process.chdir(i.projectName);const e=["prisma","@prisma/client","typescript","@types/node","ts-node"];i.tailwindcss&&e.push("tailwindcss","autoprefixer","postcss"),await installDependencies(t,e),execSync("npx prisma init",{stdio:"inherit"}),execSync("npx tsc --init",{stdio:"inherit"}),i.tailwindcss&&execSync("npx tailwindcss init -p",{stdio:"inherit"}),await createDirectoryStructure(t,i),i.tailwindcss&&execSync("npx tailwindcss -i ./public/css/tailwind.css -o ./public/css/styles.css --minify",{stdio:"inherit"});const s=path.join(t,"settings","project-settings.js"),c=`export const projectSettings = {\n PROJECT_NAME: "${i.projectName}",\n PROJECT_ROOT_PATH: "${t.replace(/\\/g,"\\\\")}",\n PHP_ROOT_PATH_EXE: "D:\\\\xampp\\\\php\\\\php.exe",\n PHP_GENERATE_CLASS_PATH: "src/app/classes/prisma",\n };`;fs.writeFileSync(s,c)}catch(i){process.exit(1)}}main();
@@ -2,6 +2,8 @@
2
2
 
3
3
  namespace App\Api;
4
4
 
5
+ require_once __DIR__ . "/../../../bootstrap.php";
6
+
5
7
  use App\Classes\Prisma\Prisma;
6
8
 
7
9
  if (!empty($_SERVER["HTTP_X_REQUESTED_WITH"]) && $_SERVER["HTTP_X_REQUESTED_WITH"] == "XMLHttpRequest") {
@@ -24,16 +26,36 @@ if (!empty($_SERVER["HTTP_X_REQUESTED_WITH"]) && $_SERVER["HTTP_X_REQUESTED_WITH
24
26
  }
25
27
 
26
28
  $prisma = new Prisma();
29
+ // Ensure that we correctly handle the case where $className might not directly map to a property.
30
+ if (!property_exists($prisma, $className)) {
31
+ echo "Error: Property $className not found in Prisma class!";
32
+ exit;
33
+ }
27
34
  $instance = $prisma->$className;
35
+
28
36
  if (!method_exists($instance, $methodName)) {
29
37
  echo "Error: Method $methodName not found in class $fullClassName!";
30
38
  exit;
31
39
  }
32
40
 
33
- $result = $instance->$methodName(...$params);
34
- if (is_object($result)) {
35
- $result = (array) $result;
41
+ // Check if $params is correctly structured for the expected arguments.
42
+ // Adjust the logic here based on how $params should be passed to the method.
43
+ // This example assumes $methodName expects an array of arguments.
44
+ if (is_array($params)) {
45
+ // Attempt to call the method with unpacked arguments.
46
+ try {
47
+ $result = $instance->$methodName($params);
48
+ if (is_object($result)) {
49
+ $result = (array) $result;
50
+ }
51
+ echo json_encode($result, JSON_INVALID_UTF8_IGNORE);
52
+ } catch (\ArgumentCountError $e) {
53
+ echo "Error: Incorrect number of arguments provided for $methodName method.";
54
+ } catch (\Exception $e) {
55
+ // Handle other potential errors here.
56
+ echo "Error: An error occurred while executing $methodName method. " . $e->getMessage();
57
+ }
58
+ } else {
59
+ echo "Error: Parameters for $methodName method are not correctly formatted or missing.";
36
60
  }
37
-
38
- echo json_encode($result, JSON_INVALID_UTF8_IGNORE);
39
61
  }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "create-prisma-php-app",
3
- "version": "1.0.13",
3
+ "version": "1.1.1",
4
4
  "description": "Prisma-PHP: A Revolutionary Library Bridging PHP with Prisma ORM",
5
5
  "main": "dist/index.js",
6
6
  "type": "module",
@@ -1,7 +0,0 @@
1
- {
2
- "name": "prisma-client-php",
3
- "type": "module",
4
- "bin": {
5
- "php": "index.js"
6
- }
7
- }
File without changes