[
  {
    "path": ".editorconfig",
    "content": "root = true\n\n[*]\nindent_style = space\nindent_size = 2\nend_of_line = lf\ncharset = utf-8\ntrim_trailing_whitespace = true\ninsert_final_newline = true\n\n[Makefile]\nindent_style = tab\n\n[*.php]\nindent_size = 4\n"
  },
  {
    "path": ".gitattributes",
    "content": "* text=auto\n/.github export-ignore\n/tests export-ignore\n/.editorconfig export-ignore\n/.gitattributes export-ignore\n/.gitignore export-ignore\n/.travis.yml export-ignore\n/.styleci.yml export-ignore\n/.sensiolabs.yml export-ignore\n/.coveralls.yml export-ignore\n/phpunit.xml export-ignore\n/CHANGELOG-* export-ignore\n/CONTRIBUTING.md export-ignore\n/CODE_OF_CONDUCT.md export-ignore\n"
  },
  {
    "path": ".github/workflows/default.yml",
    "content": "name: Run tests\n\non:\n  push:\n  schedule:\n    - cron: '0 0 * * *'\n\njobs:\n  php-tests:\n    runs-on: ${{ matrix.os }}\n\n    strategy:\n      matrix:\n        php: [7.4, 7.3, 7.2]\n        laravel: [8.*, 7.*, 6.*]\n        dependency-version: [prefer-lowest, prefer-stable]\n        os: [ubuntu-latest, windows-latest]\n        include:\n          - laravel: 8.*\n            testbench: 6.*\n          - laravel: 7.*\n            testbench: 5.*\n          - laravel: 6.*\n            testbench: 4.*\n        exclude:\n          - laravel: 8.*\n            php: 7.2\n\n    name: P${{ matrix.php }} - L${{ matrix.laravel }} - ${{ matrix.dependency-version }} - ${{ matrix.os }}\n\n    steps:\n      - name: Checkout code\n        uses: actions/checkout@v1\n\n      - name: Setup PHP\n        uses: shivammathur/setup-php@v1\n        with:\n          php-version: ${{ matrix.php }}\n          extensions: dom, curl, libxml, mbstring, zip, pcntl, pdo, sqlite, pdo_sqlite, bcmath, soap, intl, gd, exif, iconv, imagick\n          coverage: none\n\n      - name: Install dependencies\n        run: |\n          composer require \"laravel/framework:${{ matrix.laravel }}\" \"orchestra/testbench:${{ matrix.testbench }}\" --no-interaction --no-update\n          composer update --${{ matrix.dependency-version }} --prefer-dist --no-interaction --no-suggest\n"
  },
  {
    "path": ".gitignore",
    "content": "/vendor\n/.idea/\n/node_modules\n/composer.lock\n/.phpunit.result.cache\n"
  },
  {
    "path": ".styleci.yml",
    "content": "preset: laravel\n"
  },
  {
    "path": "LICENSE",
    "content": "The MIT License (MIT)\n\nCopyright (c) 2016 Alexander Melihov <amelihovv@ya.ru>\n\nPermission is hereby granted, free of charge, to any person obtaining a copy\nof this software and associated documentation files (the \"Software\"), to deal\nin the Software without restriction, including without limitation the rights\nto use, copy, modify, merge, publish, distribute, sublicense, and/or sell\ncopies of the Software, and to permit persons to whom the Software is\nfurnished to do so, subject to the following conditions:\n\nThe above copyright notice and this permission notice shall be included in all\ncopies or substantial portions of the Software.\n\nTHE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\nIMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\nFITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\nAUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\nLIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\nOUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\nSOFTWARE.\n\n"
  },
  {
    "path": "README.md",
    "content": "Laravel package generator\n=========================\n\n[![GitHub Workflow Status](https://github.com/melihovv/laravel-package-generator/workflows/Run%20tests/badge.svg)](https://github.com/melihovv/laravel-package-generator/actions)\n[![styleci](https://styleci.io/repos/96041272/shield)](https://styleci.io/repos/96041272)\n\n[![Packagist](https://img.shields.io/packagist/v/melihovv/laravel-package-generator.svg)](https://packagist.org/packages/melihovv/laravel-package-generator)\n[![Packagist](https://poser.pugx.org/melihovv/laravel-package-generator/d/total.svg)](https://packagist.org/packages/melihovv/laravel-package-generator)\n[![Packagist](https://img.shields.io/packagist/l/melihovv/laravel-package-generator.svg)](https://packagist.org/packages/melihovv/laravel-package-generator)\n\nSimple package to quickly generate basic structure for other laravel packages.\n\n## Install\n\nInstall via composer\n```bash\ncomposer require --dev melihovv/laravel-package-generator\n```\n\nPublish package config if you want customize default values\n```bash\nphp artisan vendor:publish --provider=\"Melihovv\\LaravelPackageGenerator\\ServiceProvider\" --tag=\"config\"\n```\n\n## Available commands\n\n### php artisan package:new -i {vendor} {package}\n\nCreate new package.\n\nExample: `php artisan package:new Melihovv SomeAwesomePackage`\n\nThis command will:\n\n* Create `packages/melihovv/some-awesome-package` folder\n* Register package in app composer.json\n* Copy package skeleton from skeleton folder to created folder (you can provide\nyour custom skeleton path in config)\n* Run `git init packages/melihovv/some-awesome-package`\n* Run `composer update melihovv/some-awesome-package`\n* Run `composer dump-autoload`\n\nWith interactive `-i` flag you will be prompted for every needed value from you.\n\n### php artisan package:remove {vendor} {package}\n\nRemove the existing package.\n\nExample: `php artisan package:remove Melihovv SomeAwesomePackage`\n\nThis command will:\n\n* Run `composer remove melihovv/some-awesome-package`\n* Remove `packages/melihovv/some-awesome-package` folder\n* Unregister package in app composer.json\n* Run `composer dump-autoload`\n\nInteractive mode also possible.\n\n## Custom skeleton\n\nThis package will copy all folders and files from specified skeleton path to\npackage folder. You can use templates in your skeleton. All files with `tpl`\nextension will be provided with some variables available to use in them. `tpl`\nextension will be stripped.\n\nAvailable variables to use in templates:\n\n* vendor (e.g. Melihovv)\n* package (e.g. SomeAwesomePackage)\n* vendorFolderName (e.g. melihovv)\n* packageFolderName (e.g. some-awesome-package)\n* packageHumanName (e.g. Some awesome package)\n* composerName (e.g. melihovv/some-awesome-package)\n* composerDesc (e.g. A some awesome package)\n* composerKeywords (e.g. some,awesome,package)\n* licence (e.g. MIT)\n* phpVersion (e.g. >=7.0)\n* aliasName (e.g. some-awesome-package)\n* configFileName (e.g. some-awesome-package)\n* year (e.g. 2017)\n* name (e.g. Alexander Melihov)\n* email (e.g. amelihovv@ya.ru)\n* githubPackageUrl (e.g. https://github.com/melihov/some-awesome-package)\n\n## Things you need to do manually:\n\n* In README.md:\n  * StyleCI repository identifier\n  * Package description\n  * Usage section\n\n## Security\n\nIf you discover any security related issues, please email amelihovv@ya.ru instead of using the issue tracker.\n\n## Credits\n\n- [Alexander Melihov](https://github.com/melihovv)\n- [All contributors](https://github.com/melihovv/laravel-package-generator/graphs/contributors)\n"
  },
  {
    "path": "composer.json",
    "content": "{\n  \"name\": \"melihovv/laravel-package-generator\",\n  \"description\": \"A laravel package generator\",\n  \"license\": \"MIT\",\n  \"keywords\": [\n    \"laravel\",\n    \"package\",\n    \"generator\"\n  ],\n  \"type\": \"library\",\n  \"authors\": [\n    {\n      \"name\": \"Alexander Melihov\",\n      \"email\": \"amelihovv@ya.ru\"\n    }\n  ],\n  \"require\": {\n    \"php\": \">=7.2\",\n    \"illuminate/container\": \"^6.0|^7.0|^8.0\",\n    \"illuminate/console\": \"^6.0|^7.0|^8.0\",\n    \"illuminate/filesystem\": \"^6.0|^7.0|^8.0\",\n    \"illuminate/support\": \"^6.0|^7.0|^8.0\",\n    \"illuminate/view\": \"^6.0|^7.0|^8.0\"\n  },\n  \"autoload\": {\n    \"psr-4\": {\n      \"Melihovv\\\\LaravelPackageGenerator\\\\\": \"src\"\n    }\n  },\n  \"extra\": {\n    \"laravel\": {\n      \"providers\": [\n        \"Melihovv\\\\LaravelPackageGenerator\\\\ServiceProvider\"\n      ]\n    }\n  },\n  \"config\": {\n    \"preferred-install\": \"dist\",\n    \"sort-packages\": true,\n    \"optimize-autoloader\": true\n  }\n}\n"
  },
  {
    "path": "config/package-generator.php",
    "content": "<?php\n\nreturn [\n\n    /*\n    |--------------------------------------------------------------------------\n    | Custom skeleton directory path\n    |--------------------------------------------------------------------------\n    |\n    | This value allows to override default package skeleton.\n    | Relative to base project path. Example: storage/skeleton.\n    |\n    */\n\n    'skeleton_dir_path' => null,\n\n];\n"
  },
  {
    "path": "skeleton/.editorconfig",
    "content": "root = true\n\n[*]\nindent_style = space\nindent_size = 2\nend_of_line = lf\ncharset = utf-8\ntrim_trailing_whitespace = true\ninsert_final_newline = true\n\n[Makefile]\nindent_style = tab\n\n[*.php]\nindent_size = 4\n"
  },
  {
    "path": "skeleton/.gitattributes.tpl",
    "content": "* text=auto\n/.github export-ignore\n/tests export-ignore\n/.editorconfig export-ignore\n/.gitattributes export-ignore\n/.gitignore export-ignore\n/.travis.yml export-ignore\n/.styleci.yml export-ignore\n/.sensiolabs.yml export-ignore\n/.coveralls.yml export-ignore\n/phpunit.xml export-ignore\n/CHANGELOG-* export-ignore\n/CONTRIBUTING.md export-ignore\n/CODE_OF_CONDUCT.md export-ignore\n"
  },
  {
    "path": "skeleton/.github/workflows/default.yml",
    "content": "name: Run tests\n\non:\n  push:\n  schedule:\n    - cron: '0 0 * * *'\n\njobs:\n  php-tests:\n    runs-on: ${{ matrix.os }}\n\n    strategy:\n      matrix:\n        php: [7.4, 7.3, 7.2]\n        laravel: [7.*, 6.*]\n        dependency-version: [prefer-lowest, prefer-stable]\n        os: [ubuntu-latest, windows-latest]\n        include:\n          - laravel: 8.*\n            testbench: 6.*\n          - laravel: 7.*\n            testbench: 5.*\n          - laravel: 6.*\n            testbench: 4.*\n        exclude:\n          - laravel: 8.*\n            php: 7.2\n\n    name: P${{ matrix.php }} - L${{ matrix.laravel }} - ${{ matrix.dependency-version }} - ${{ matrix.os }}\n\n    steps:\n      - name: Checkout code\n        uses: actions/checkout@v1\n\n      - name: Setup PHP\n        uses: shivammathur/setup-php@v1\n        with:\n          php-version: ${{ matrix.php }}\n          extensions: dom, curl, libxml, mbstring, zip, pcntl, pdo, sqlite, pdo_sqlite, bcmath, soap, intl, gd, exif, iconv, imagick\n          coverage: none\n\n      - name: Install dependencies\n        run: |\n          composer require \"laravel/framework:${{ matrix.laravel }}\" \"orchestra/testbench:${{ matrix.testbench }}\" --no-interaction --no-update\n          composer update --${{ matrix.dependency-version }} --prefer-dist --no-interaction --no-suggest\n\n      - name: Execute tests\n        run: ./vendor/bin/phpunit\n"
  },
  {
    "path": "skeleton/.gitignore.tpl",
    "content": "/vendor\n/.idea\n/node_modules\n/composer.lock\n/.phpunit.result.cache\n"
  },
  {
    "path": "skeleton/.styleci.yml",
    "content": "preset: laravel\n"
  },
  {
    "path": "skeleton/LICENSE.tpl",
    "content": "The MIT License (MIT)\n\nCopyright (c) <?php echo $year; ?> <?php echo $name; ?> <<?php echo $email; ?>>\n\nPermission is hereby granted, free of charge, to any person obtaining a copy\nof this software and associated documentation files (the \"Software\"), to deal\nin the Software without restriction, including without limitation the rights\nto use, copy, modify, merge, publish, distribute, sublicense, and/or sell\ncopies of the Software, and to permit persons to whom the Software is\nfurnished to do so, subject to the following conditions:\n\nThe above copyright notice and this permission notice shall be included in all\ncopies or substantial portions of the Software.\n\nTHE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\nIMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\nFITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\nAUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\nLIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\nOUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\nSOFTWARE.\n\n"
  },
  {
    "path": "skeleton/README.md.tpl",
    "content": "# <?php echo \"$packageHumanName\\n\"; ?>\n\n[![GitHub Workflow Status](https://github.com/<?php echo $vendorFolderName; ?>/<?php echo $packageFolderName; ?>/workflows/Run%20tests/badge.svg)](https://github.com/<?php echo $vendorFolderName; ?>/<?php echo $packageFolderName; ?>/actions)\n[![styleci](https://styleci.io/repos/CHANGEME/shield)](https://styleci.io/repos/CHANGEME)\n\n[![Packagist](https://img.shields.io/packagist/v/<?php echo $vendorFolderName; ?>/<?php echo $packageFolderName; ?>.svg)](https://packagist.org/packages/<?php echo $vendorFolderName; ?>/<?php echo $packageFolderName; ?>)\n[![Packagist](https://poser.pugx.org/<?php echo $vendorFolderName; ?>/<?php echo $packageFolderName; ?>/d/total.svg)](https://packagist.org/packages/<?php echo $vendorFolderName; ?>/<?php echo $packageFolderName; ?>)\n[![Packagist](https://img.shields.io/packagist/l/<?php echo $vendorFolderName; ?>/<?php echo $packageFolderName; ?>.svg)](https://packagist.org/packages/<?php echo $vendorFolderName; ?>/<?php echo $packageFolderName; ?>)\n\nPackage description: CHANGE ME\n\n## Installation\n\nInstall via composer\n```bash\ncomposer require <?php echo $vendorFolderName; ?>/<?php echo \"$packageFolderName\\n\"; ?>\n```\n\n### Publish package assets\n\n```bash\nphp artisan vendor:publish --provider=\"<?php echo $vendor; ?>\\<?php echo $package; ?>\\ServiceProvider\"\n```\n\n## Usage\n\nCHANGE ME\n\n## Security\n\nIf you discover any security related issues, please email <?php echo \"$email\\n\"; ?>\ninstead of using the issue tracker.\n\n## Credits\n\n- [<?php echo $name; ?>](<?php echo $githubPackageUrl; ?>)\n- [All contributors](<?php echo $githubPackageUrl; ?>/graphs/contributors)\n\nThis package is bootstrapped with the help of\n[melihovv/laravel-package-generator](https://github.com/melihovv/laravel-package-generator).\n"
  },
  {
    "path": "skeleton/composer.json.tpl",
    "content": "{\n  \"name\": \"<?php echo $composerName; ?>\",\n  \"description\": \"<?php echo $composerDesc; ?>\",\n  \"license\": \"<?php echo $license; ?>\",\n  \"keywords\": [\n    <?php echo \"$composerKeywords\\n\"; ?>\n  ],\n  \"type\": \"library\",\n  \"authors\": [\n    {\n      \"name\": \"<?php echo $name; ?>\",\n      \"email\": \"<?php echo $email; ?>\"\n    }\n  ],\n  \"require\": {\n    \"php\": \"<?php echo $phpVersion; ?>\",\n    \"illuminate/support\": \"^6.0|^7.0|^8.0\"\n  },\n  \"require-dev\": {\n    \"orchestra/testbench\": \"^4.0|^5.0|^6.0\",\n    \"phpunit/phpunit\": \"^8.4|^9.0\"\n  },\n  \"autoload\": {\n    \"psr-4\": {\n      \"<?php echo $vendor; ?>\\\\<?php echo $package; ?>\\\\\": \"src\"\n    }\n  },\n  \"autoload-dev\": {\n    \"psr-4\": {\n      \"<?php echo $vendor; ?>\\\\<?php echo $package; ?>\\\\Tests\\\\\": \"tests\"\n    }\n  },\n  \"scripts\": {\n    \"phpunit\": \"phpunit\"\n  },\n  \"extra\": {\n    \"laravel\": {\n      \"providers\": [\n        \"<?php echo $vendor; ?>\\\\<?php echo $package; ?>\\\\ServiceProvider\"\n      ]\n    }\n  },\n  \"config\": {\n    \"preferred-install\": \"dist\",\n    \"sort-packages\": true,\n    \"optimize-autoloader\": true\n  }\n}\n"
  },
  {
    "path": "skeleton/phpunit.xml",
    "content": "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n<phpunit backupGlobals=\"false\"\n         backupStaticAttributes=\"false\"\n         bootstrap=\"vendor/autoload.php\"\n         colors=\"true\"\n         convertErrorsToExceptions=\"true\"\n         convertNoticesToExceptions=\"true\"\n         convertWarningsToExceptions=\"true\"\n         processIsolation=\"false\"\n         stopOnFailure=\"false\">\n  <testsuites>\n    <testsuite name=\"package\">\n      <directory suffix=\"Test.php\">tests</directory>\n    </testsuite>\n  </testsuites>\n  <filter>\n    <whitelist processUncoveredFilesFromWhitelist=\"true\">\n      <directory suffix=\".php\">src</directory>\n    </whitelist>\n  </filter>\n</phpunit>\n"
  },
  {
    "path": "skeleton/src/ServiceProvider.php.tpl",
    "content": "<?php echo \"<?php\\n\"; ?>\n\nnamespace <?php echo $vendor; ?>\\<?php echo $package; ?>;\n\nclass ServiceProvider extends \\Illuminate\\Support\\ServiceProvider\n{\n    const CONFIG_PATH = __DIR__ . '/../config/<?php echo $configFileName; ?>.php';\n\n    public function boot()\n    {\n        $this->publishes([\n            self::CONFIG_PATH => config_path('<?php echo $configFileName; ?>.php'),\n        ], 'config');\n    }\n\n    public function register()\n    {\n        $this->mergeConfigFrom(\n            self::CONFIG_PATH,\n            '<?php echo $configFileName; ?>'\n        );\n\n        $this->app->bind('<?php echo $aliasName; ?>', function () {\n            return new <?php echo $package; ?>();\n        });\n    }\n}\n"
  },
  {
    "path": "src/Commands/PackageNew.php",
    "content": "<?php\n\nnamespace Melihovv\\LaravelPackageGenerator\\Commands;\n\nuse Exception;\nuse Illuminate\\Console\\Command;\nuse Melihovv\\LaravelPackageGenerator\\Commands\\Traits\\ChangesComposerJson;\nuse Melihovv\\LaravelPackageGenerator\\Commands\\Traits\\CopiesSkeleton;\nuse Melihovv\\LaravelPackageGenerator\\Commands\\Traits\\InteractsWithComposer;\nuse Melihovv\\LaravelPackageGenerator\\Commands\\Traits\\InteractsWithGit;\nuse Melihovv\\LaravelPackageGenerator\\Commands\\Traits\\ManipulatesPackageFolder;\n\nclass PackageNew extends Command\n{\n    use ChangesComposerJson;\n    use ManipulatesPackageFolder;\n    use InteractsWithComposer;\n    use CopiesSkeleton;\n    use InteractsWithGit;\n\n    /**\n     * The name and signature of the console command.\n     *\n     * @var string\n     */\n    protected $signature = 'package:new\n                            {vendor : The vendor part of the namespace}\n                            {package : The name of package for the namespace}\n                            {--i|interactive : Interactive mode}';\n\n    /**\n     * The console command description.\n     *\n     * @var string\n     */\n    protected $description = 'Create a new package.';\n\n    /**\n     * Execute the console command.\n     *\n     * @return mixed\n     */\n    public function handle()\n    {\n        $vendor = $this->getVendor();\n        $package = $this->getPackage();\n\n        $vendorFolderName = $this->getVendorFolderName($vendor);\n        $packageFolderName = $this->getPackageFolderName($package);\n\n        $relPackagePath = \"packages/$vendorFolderName/$packageFolderName\";\n        $packagePath = base_path($relPackagePath);\n\n        try {\n            $this->createPackageFolder($packagePath);\n            $this->registerPackage($vendorFolderName, $packageFolderName, $relPackagePath);\n            $this->copySkeleton($packagePath, $vendor, $package, $vendorFolderName, $packageFolderName);\n            $this->initRepo($packagePath);\n            $this->composerUpdatePackage($vendorFolderName, $packageFolderName);\n            $this->composerDumpAutoload();\n\n            $this->info('Finished. Are you ready to write awesome package?');\n\n            return 0;\n        } catch (Exception $e) {\n            $this->error($e->getMessage());\n\n            return -1;\n        }\n    }\n}\n"
  },
  {
    "path": "src/Commands/PackageRemove.php",
    "content": "<?php\n\nnamespace Melihovv\\LaravelPackageGenerator\\Commands;\n\nuse Exception;\nuse Illuminate\\Console\\Command;\nuse Melihovv\\LaravelPackageGenerator\\Commands\\Traits\\ChangesComposerJson;\nuse Melihovv\\LaravelPackageGenerator\\Commands\\Traits\\InteractsWithComposer;\nuse Melihovv\\LaravelPackageGenerator\\Commands\\Traits\\InteractsWithUser;\nuse Melihovv\\LaravelPackageGenerator\\Commands\\Traits\\ManipulatesPackageFolder;\n\nclass PackageRemove extends Command\n{\n    use ChangesComposerJson;\n    use ManipulatesPackageFolder;\n    use InteractsWithUser;\n    use InteractsWithComposer;\n\n    /**\n     * The name and signature of the console command.\n     *\n     * @var string\n     */\n    protected $signature = 'package:remove\n                            {vendor : The vendor part of the namespace}\n                            {package : The name of package for the namespace}\n                            {--i|interactive : Interactive mode}';\n\n    /**\n     * The console command description.\n     *\n     * @var string\n     */\n    protected $description = 'Remove the existing package.';\n\n    /**\n     * Execute the console command.\n     *\n     * @return mixed\n     */\n    public function handle()\n    {\n        $vendor = $this->getVendor();\n        $package = $this->getPackage();\n\n        $vendorFolderName = $this->getVendorFolderName($vendor);\n        $packageFolderName = $this->getPackageFolderName($package);\n\n        $relPackagePath = \"packages/$vendorFolderName/$packageFolderName\";\n        $packagePath = base_path($relPackagePath);\n\n        try {\n            $this->composerRemovePackage($vendorFolderName, $packageFolderName);\n            $this->removePackageFolder($packagePath);\n            $this->unregisterPackage($vendor, $package, \"packages/$vendorFolderName/$packageFolderName\");\n            $this->composerDumpAutoload();\n\n            return 0;\n        } catch (Exception $e) {\n            $this->error($e->getMessage());\n\n            return -1;\n        }\n    }\n}\n"
  },
  {
    "path": "src/Commands/Traits/ChangesComposerJson.php",
    "content": "<?php\n\nnamespace Melihovv\\LaravelPackageGenerator\\Commands\\Traits;\n\nuse Illuminate\\Contracts\\Filesystem\\FileNotFoundException;\nuse Illuminate\\Support\\Arr;\nuse Illuminate\\Support\\Facades\\File;\nuse Melihovv\\LaravelPackageGenerator\\Exceptions\\RuntimeException;\n\ntrait ChangesComposerJson\n{\n    /**\n     * Register package in composer.json.\n     *\n     * @param $vendor\n     * @param $package\n     * @param $relPackagePath\n     *\n     * @throws RuntimeException\n     */\n    protected function registerPackage($vendor, $package, $relPackagePath)\n    {\n        $this->info('Register package in composer.json.');\n\n        $composerJson = $this->loadComposerJson();\n\n        if (! isset($composerJson['repositories'])) {\n            Arr::set($composerJson, 'repositories', []);\n        }\n\n        $filtered = array_filter($composerJson['repositories'], function ($repository) use ($relPackagePath) {\n            return $repository['type'] === 'path'\n                && $repository['url'] === $relPackagePath;\n        });\n\n        if (count($filtered) === 0) {\n            $this->info('Register composer repository for package.');\n\n            $composerJson['repositories'][] = (object) [\n                'type' => 'path',\n                'url' => $relPackagePath,\n            ];\n        } else {\n            $this->info('Composer repository for package is already registered.');\n        }\n\n        Arr::set($composerJson, \"require.$vendor/$package\", 'dev-master');\n\n        $this->saveComposerJson($composerJson);\n\n        $this->info('Package was successfully registered in composer.json.');\n    }\n\n    /**\n     * Unregister package from composer.json.\n     *\n     * @param $vendor\n     * @param $package\n     *\n     * @throws FileNotFoundException\n     * @throws RuntimeException\n     */\n    protected function unregisterPackage($vendor, $package, $relPackagePath)\n    {\n        $this->info('Unregister package from composer.json.');\n\n        $composerJson = $this->loadComposerJson();\n\n        unset($composerJson['require'][\"$vendor\\\\$package\\\\\"]);\n\n        $repositories = array_filter($composerJson['repositories'], function ($repository) use ($relPackagePath) {\n            return $repository['type'] !== 'path'\n                || $repository['url'] !== $relPackagePath;\n        });\n\n        $composerJson['repositories'] = $repositories;\n\n        if (count($composerJson['repositories']) === 0) {\n            unset($composerJson['repositories']);\n        }\n\n        $this->saveComposerJson($composerJson);\n\n        $this->info('Package was successfully unregistered from composer.json.');\n    }\n\n    /**\n     * Load and parse content of composer.json.\n     *\n     * @return array\n     *\n     * @throws FileNotFoundException\n     * @throws RuntimeException\n     */\n    protected function loadComposerJson()\n    {\n        $composerJsonPath = $this->getComposerJsonPath();\n\n        if (! File::exists($composerJsonPath)) {\n            throw new FileNotFoundException('composer.json does not exist');\n        }\n\n        $composerJsonContent = File::get($composerJsonPath);\n        $composerJson = json_decode($composerJsonContent, true);\n\n        if (! is_array($composerJson)) {\n            throw new RuntimeException(\"Invalid composer.json file [$composerJsonPath]\");\n        }\n\n        return $composerJson;\n    }\n\n    /**\n     * @param array $composerJson\n     *\n     * @throws RuntimeException\n     */\n    protected function saveComposerJson($composerJson)\n    {\n        $newComposerJson = json_encode(\n            $composerJson,\n            JSON_PRETTY_PRINT | JSON_UNESCAPED_SLASHES\n        );\n\n        $composerJsonPath = $this->getComposerJsonPath();\n        if (File::put($composerJsonPath, $newComposerJson) === false) {\n            throw new RuntimeException(\"Cannot write to composer.json [$composerJsonPath]\");\n        }\n    }\n\n    /**\n     * Get composer.json path.\n     *\n     * @return string\n     */\n    protected function getComposerJsonPath()\n    {\n        return base_path('composer.json');\n    }\n}\n"
  },
  {
    "path": "src/Commands/Traits/CopiesSkeleton.php",
    "content": "<?php\n\nnamespace Melihovv\\LaravelPackageGenerator\\Commands\\Traits;\n\nuse Exception;\nuse Illuminate\\Support\\Facades\\File;\nuse Illuminate\\Support\\Str;\nuse Illuminate\\View\\Engines\\PhpEngine;\nuse Melihovv\\LaravelPackageGenerator\\Exceptions\\RuntimeException;\n\ntrait CopiesSkeleton\n{\n    use InteractsWithUser;\n\n    protected $packageBaseDir = __DIR__.'/../../..';\n\n    /**\n     * Copy skeleton to package folder.\n     *\n     * @param string $packagePath\n     * @param string $vendor\n     * @param string $package\n     * @param string $vendorFolderName\n     * @param string $packageFolderName\n     *\n     * @throws RuntimeException\n     */\n    protected function copySkeleton(\n        $packagePath,\n        $vendor,\n        $package,\n        $vendorFolderName,\n        $packageFolderName\n    ) {\n        $this->info('Copy skeleton.');\n\n        $skeletonDirPath = $this->getPathFromConfig(\n            'skeleton_dir_path', $this->packageBaseDir.'/skeleton'\n        );\n\n        foreach (File::allFiles($skeletonDirPath, true) as $filePath) {\n            $filePath = realpath($filePath);\n\n            $destFilePath = Str::replaceFirst(\n                $skeletonDirPath, $packagePath, $filePath\n            );\n\n            $this->copyFileWithDirsCreating($filePath, $destFilePath);\n        }\n\n        $this->copyStubs($packagePath, $package, $packageFolderName);\n\n        $variables = $this->getVariables(\n            $vendor, $package, $vendorFolderName, $packageFolderName\n        );\n        $this->replaceTemplates($packagePath, $variables);\n\n        $this->info('Skeleton was successfully copied.');\n    }\n\n    /**\n     * Copy stubs.\n     *\n     * @param $packagePath\n     * @param $package\n     * @param $packageFolderName\n     */\n    protected function copyStubs($packagePath, $package, $packageFolderName)\n    {\n        $facadeFilePath = $this->packageBaseDir.'/stubs/Facade.php.tpl';\n        $mainClassFilePath = $this->packageBaseDir.'/stubs/MainClass.php.tpl';\n        $mainClassTestFilePath = $this->packageBaseDir.'/stubs/MainClassTest.php.tpl';\n        $configFilePath = $this->packageBaseDir.'/stubs/config.php';\n\n        $filePaths = [\n            $facadeFilePath => \"$packagePath/src/Facades/$package.php.tpl\",\n            $mainClassFilePath => \"$packagePath/src/$package.php.tpl\",\n            $mainClassTestFilePath => \"$packagePath/tests/{$package}Test.php.tpl\",\n            $configFilePath => \"$packagePath/config/$packageFolderName.php\",\n        ];\n\n        foreach ($filePaths as $filePath => $destFilePath) {\n            $this->copyFileWithDirsCreating($filePath, $destFilePath);\n        }\n    }\n\n    /**\n     * Substitute all variables in *.tpl files and remove tpl extension.\n     *\n     * @param string $packagePath\n     * @param array $variables\n     */\n    protected function replaceTemplates($packagePath, $variables)\n    {\n        $phpEngine = app()->make(PhpEngine::class);\n\n        foreach (File::allFiles($packagePath, true) as $filePath) {\n            $filePath = realpath($filePath);\n\n            if (! Str::endsWith($filePath, '.tpl')) {\n                continue;\n            }\n\n            try {\n                $newFileContent = $phpEngine->get($filePath, $variables);\n            } catch (Exception $e) {\n                $this->error(\"Template [$filePath] contains syntax errors\");\n                $this->error($e->getMessage());\n                continue;\n            }\n\n            $filePathWithoutTplExt = Str::replaceLast(\n                '.tpl', '', $filePath\n            );\n\n            File::put($filePathWithoutTplExt, $newFileContent);\n            File::delete($filePath);\n        }\n    }\n\n    /**\n     * Copy source file to destination with needed directories creating.\n     *\n     * @param string $src\n     * @param string $dest\n     */\n    protected function copyFileWithDirsCreating($src, $dest)\n    {\n        $dirPathOfDestFile = dirname($dest);\n\n        if (! File::exists($dirPathOfDestFile)) {\n            File::makeDirectory($dirPathOfDestFile, 0755, true);\n        }\n\n        if (! File::exists($dest)) {\n            File::copy($src, $dest);\n        }\n    }\n\n    /**\n     * Get variables for substitution in templates.\n     *\n     * @param string $vendor\n     * @param string $package\n     * @param string $vendorFolderName\n     * @param string $packageFolderName\n     *\n     * @return array\n     */\n    protected function getVariables(\n        $vendor,\n        $package,\n        $vendorFolderName,\n        $packageFolderName\n    ) {\n        $packageWords = str_replace('-', ' ', Str::snake($packageFolderName));\n\n        $composerDescription = $this->askUser(\n            'The composer description?', \"A $packageWords\"\n        );\n        $composerKeywords = $this->getComposerKeywords($packageWords);\n\n        $packageHumanName = $this->askUser(\n            'The package human name?', Str::title($packageWords)\n        );\n\n        return [\n            'vendor' => $vendor,\n            'package' => $package,\n            'vendorFolderName' => $vendorFolderName,\n            'packageFolderName' => $packageFolderName,\n            'packageHumanName' => $packageHumanName,\n\n            'composerName' => \"$vendorFolderName/$packageFolderName\",\n            'composerDesc' => $composerDescription,\n            'composerKeywords' => $composerKeywords,\n            'license' => $this->askUser('The package licence?', 'MIT'),\n            'phpVersion' => $this->askUser('Php version constraint?', '>=7.2'),\n\n            'aliasName' => $packageFolderName,\n            'configFileName' => $packageFolderName,\n\n            'year' => date('Y'),\n\n            'name' => $this->askUser('Your name?'),\n            'email' => $this->askUser('Your email?'),\n            'githubPackageUrl' => \"https://github.com/$vendorFolderName/$packageFolderName\",\n        ];\n    }\n\n    /**\n     * Get path from config.\n     *\n     * @param string $configName\n     * @param string $default\n     *\n     * @return string\n     *\n     * @throws RuntimeException\n     */\n    protected function getPathFromConfig($configName, $default)\n    {\n        $path = config(\"package-generator.$configName\");\n\n        if (empty($path)) {\n            $path = $default;\n        } else {\n            $path = base_path($path);\n        }\n\n        $realPath = realpath($path);\n\n        if ($realPath === false) {\n            throw RuntimeException::noAccessTo($path);\n        }\n\n        return $realPath;\n    }\n\n    /**\n     * Get composer keywords.\n     *\n     * @param $packageWords\n     *\n     * @return string\n     */\n    protected function getComposerKeywords($packageWords)\n    {\n        $keywords = $this->askUser(\n            'The composer keywords? (comma delimited)', str_replace(' ', ',', $packageWords)\n        );\n        $keywords = explode(',', $keywords);\n        $keywords = array_map(function ($keyword) {\n            return \"\\\"$keyword\\\"\";\n        }, $keywords);\n\n        return implode(\",\\n\".str_repeat(' ', 4), $keywords);\n    }\n}\n"
  },
  {
    "path": "src/Commands/Traits/InteractsWithComposer.php",
    "content": "<?php\n\nnamespace Melihovv\\LaravelPackageGenerator\\Commands\\Traits;\n\nuse Melihovv\\LaravelPackageGenerator\\Exceptions\\RuntimeException;\n\ntrait InteractsWithComposer\n{\n    /**\n     * Run \"composer dump-autoload\".\n     */\n    protected function composerDumpAutoload()\n    {\n        $this->composerRunCommand('composer dump-autoload');\n    }\n\n    /**\n     * Run \"composer update $vendor/$package\".\n     *\n     * @param string $vendor\n     * @param string $package\n     */\n    protected function composerUpdatePackage($vendor, $package)\n    {\n        $this->composerRunCommand(\"composer update --ignore-platform-reqs $vendor/$package\");\n    }\n\n    /**\n     * Run \"composer remove $vendor/$package\".\n     *\n     * @param string $vendor\n     * @param string $package\n     */\n    protected function composerRemovePackage($vendor, $package)\n    {\n        $this->composerRunCommand(\"composer remove --ignore-platform-reqs $vendor/$package\");\n    }\n\n    /**\n     * Run arbitrary composer command.\n     *\n     * @param $command\n     */\n    protected function composerRunCommand($command)\n    {\n        $this->info(\"Run \\\"$command\\\".\");\n\n        $output = [];\n        exec($command, $output, $returnStatusCode);\n\n        if ($returnStatusCode !== 0) {\n            throw RuntimeException::commandExecutionFailed($command, $returnStatusCode);\n        }\n\n        $this->info(\"\\\"$command\\\" was successfully ran.\");\n    }\n}\n"
  },
  {
    "path": "src/Commands/Traits/InteractsWithGit.php",
    "content": "<?php\n\nnamespace Melihovv\\LaravelPackageGenerator\\Commands\\Traits;\n\nuse Illuminate\\Support\\Facades\\File;\nuse Melihovv\\LaravelPackageGenerator\\Exceptions\\RuntimeException;\n\ntrait InteractsWithGit\n{\n    /**\n     * Clone repo.\n     *\n     * @param $url\n     * @param $dest\n     * @param $branch\n     *\n     * @throws RuntimeException\n     */\n    protected function cloneRepo($url, $dest, $branch)\n    {\n        $command = \"git clone --branch=$branch $url $dest\";\n        $this->info(\"Run \\\"$command\\\".\");\n\n        File::makeDirectory($dest, 0755, true);\n\n        $output = [];\n        exec($command, $output, $returnStatusCode);\n\n        if ($returnStatusCode !== 0) {\n            throw RuntimeException::commandExecutionFailed(\n                $command, $returnStatusCode\n            );\n        }\n\n        $this->info(\"\\\"$command\\\" was successfully ran.\");\n    }\n\n    /**\n     * Init git repo.\n     * @param string $repoPath\n     */\n    protected function initRepo($repoPath)\n    {\n        $command = \"git init $repoPath\";\n        $this->info(\"Run \\\"$command\\\".\");\n\n        $output = [];\n        exec($command, $output, $returnStatusCode);\n\n        if ($returnStatusCode !== 0) {\n            throw RuntimeException::commandExecutionFailed(\n                $command, $returnStatusCode\n            );\n        }\n\n        $this->info(\"\\\"$command\\\" was successfully ran.\");\n    }\n}\n"
  },
  {
    "path": "src/Commands/Traits/InteractsWithUser.php",
    "content": "<?php\n\nnamespace Melihovv\\LaravelPackageGenerator\\Commands\\Traits;\n\nuse Illuminate\\Support\\Str;\n\ntrait InteractsWithUser\n{\n    /**\n     * Get vendor part of the namespace part.\n     *\n     * @param string $default\n     *\n     * @return string\n     */\n    protected function getVendor($default = '')\n    {\n        $vendor = $this->argument('vendor') ?: $default;\n\n        return $this->askUser('The vendor name?', $vendor);\n    }\n\n    /**\n     * Get the name of package for the namespace.\n     *\n     * @param string $default\n     *\n     * @return string\n     */\n    protected function getPackage($default = '')\n    {\n        $package = $this->argument('package') ?: $default;\n\n        return $this->askUser('The package name?', $package);\n    }\n\n    /**\n     * Get vendor folder name.\n     *\n     * @param string $vendor\n     *\n     * @return string\n     */\n    protected function getVendorFolderName($vendor)\n    {\n        $vendorFolderName = Str::kebab($vendor);\n\n        return $this->askUser('The vendor folder name?', $vendorFolderName);\n    }\n\n    /**\n     * Get package folder name.\n     *\n     * @param string $package\n     *\n     * @return string\n     */\n    protected function getPackageFolderName($package)\n    {\n        $packageFolderName = Str::kebab($package);\n\n        return $this->askUser('The package folder name?', $packageFolderName);\n    }\n\n    /**\n     * Ask user.\n     *\n     * @param $question\n     * @param $defaultValue\n     *\n     * @return string\n     */\n    protected function askUser($question, $defaultValue = '')\n    {\n        if ($this->option('interactive')) {\n            return $this->ask($question, $defaultValue);\n        }\n\n        return $defaultValue;\n    }\n}\n"
  },
  {
    "path": "src/Commands/Traits/ManipulatesPackageFolder.php",
    "content": "<?php\n\nnamespace Melihovv\\LaravelPackageGenerator\\Commands\\Traits;\n\nuse Illuminate\\Support\\Facades\\File;\nuse Melihovv\\LaravelPackageGenerator\\Exceptions\\RuntimeException;\n\ntrait ManipulatesPackageFolder\n{\n    /**\n     * Create package folder.\n     *\n     * @param string $packagePath\n     *\n     * @throws RuntimeException\n     */\n    protected function createPackageFolder($packagePath)\n    {\n        $this->info('Create package folder.');\n\n        if (File::exists($packagePath)) {\n            $this->info('Package folder already exists. Skipping.');\n\n            return;\n        }\n\n        if (! File::makeDirectory($packagePath, 0755, true)) {\n            throw new RuntimeException('Cannot create package folder');\n        }\n\n        $this->info('Package folder was successfully created.');\n    }\n\n    /**\n     * Remove package folder.\n     *\n     * @param $packagePath\n     *\n     * @throws RuntimeException\n     */\n    protected function removePackageFolder($packagePath)\n    {\n        $this->info('Remove package folder.');\n\n        if (File::exists($packagePath)) {\n            if (! File::deleteDirectory($packagePath)) {\n                throw new RuntimeException('Cannot remove package folder');\n            }\n\n            $this->info('Package folder was successfully removed.');\n        } else {\n            $this->info('Package folder does not exists. Skipping.');\n        }\n    }\n}\n"
  },
  {
    "path": "src/Exceptions/RuntimeException.php",
    "content": "<?php\n\nnamespace Melihovv\\LaravelPackageGenerator\\Exceptions;\n\nclass RuntimeException extends \\RuntimeException\n{\n    /**\n     * @param string $command\n     * @param int $exitStatusCode\n     * @param int $code\n     * @param \\Exception|\\Throwable|null $previous\n     * @return static\n     */\n    public static function commandExecutionFailed(\n        $command,\n        $exitStatusCode,\n        $code = 0,\n        $previous = null\n    ) {\n        $message = sprintf(\n            \"\\\"$command\\\" exited with %s status code\",\n            $exitStatusCode\n        );\n\n        return new static($message, $code, $previous);\n    }\n\n    /**\n     * @param string $path\n     * @param int $code\n     * @param \\Exception|\\Throwable|null $previous\n     * @return static\n     */\n    public static function noAccessTo(\n        $path,\n        $code = 0,\n        $previous = null\n    ) {\n        return new static(\"No access to [$path]\", $code, $previous);\n    }\n}\n"
  },
  {
    "path": "src/ServiceProvider.php",
    "content": "<?php\n\nnamespace Melihovv\\LaravelPackageGenerator;\n\nuse Melihovv\\LaravelPackageGenerator\\Commands\\PackageNew;\nuse Melihovv\\LaravelPackageGenerator\\Commands\\PackageRemove;\n\nclass ServiceProvider extends \\Illuminate\\Support\\ServiceProvider\n{\n    const CONFIG_PATH = __DIR__.'/../config/package-generator.php';\n\n    public function boot()\n    {\n        $this->publishes([\n            self::CONFIG_PATH => config_path('package-generator.php'),\n        ], 'config');\n\n        if ($this->app->runningInConsole()) {\n            $this->commands([\n                PackageNew::class,\n                PackageRemove::class,\n            ]);\n        }\n    }\n\n    public function register()\n    {\n        $this->mergeConfigFrom(\n            self::CONFIG_PATH,\n            'package-generator'\n        );\n    }\n}\n"
  },
  {
    "path": "stubs/Facade.php.tpl",
    "content": "<?php echo \"<?php\\n\"; ?>\n\nnamespace <?php echo $vendor; ?>\\<?php echo $package; ?>\\Facades;\n\nuse Illuminate\\Support\\Facades\\Facade;\n\nclass <?php echo $package ?> extends Facade\n{\n    protected static function getFacadeAccessor()\n    {\n        return '<?php echo $aliasName; ?>';\n    }\n}\n"
  },
  {
    "path": "stubs/MainClass.php.tpl",
    "content": "<?php echo \"<?php\\n\"; ?>\n\nnamespace <?php echo $vendor; ?>\\<?php echo $package; ?>;\n\nclass <?php echo $package; ?>\n{\n}\n"
  },
  {
    "path": "stubs/MainClassTest.php.tpl",
    "content": "<?php echo \"<?php\\n\"; ?>\n\nnamespace <?php echo $vendor; ?>\\<?php echo $package; ?>\\Tests;\n\nuse <?php echo $vendor; ?>\\<?php echo $package; ?>\\Facades\\<?php echo $package; ?>;\nuse <?php echo $vendor; ?>\\<?php echo $package; ?>\\ServiceProvider;\nuse Orchestra\\Testbench\\TestCase;\n\nclass <?php echo $package; ?>Test extends TestCase\n{\n    protected function getPackageProviders($app)\n    {\n        return [ServiceProvider::class];\n    }\n\n    protected function getPackageAliases($app)\n    {\n        return [\n            '<?php echo $aliasName; ?>' => <?php echo $package; ?>::class,\n        ];\n    }\n\n    public function testExample()\n    {\n        $this->assertEquals(1, 1);\n    }\n}\n"
  },
  {
    "path": "stubs/config.php",
    "content": "<?php\n\nreturn [\n\n];\n"
  }
]