PHP code example of aybarsm / laravel-git
1. Go to this page and download the library: Download aybarsm/laravel-git library . Choose the download type require .
2. Extract the ZIP file and open the index.php.
3. Add this code to the index.php.
<?php
require_once('vendor/autoload.php');
/* Start to develop here. Best regards https://php-download.com/ */
aybarsm / laravel-git example snippets
return [
'repos' => [
'default' => base_path(),
],
'concretes' => [
'Git' => \Aybarsm\Laravel\Git\Git::class,
'GitRepo' => \Aybarsm\Laravel\Git\GitRepo::class,
],
'commands' => [
'bisect' => [
'subcommands' => ['start', 'bad', 'new', 'good', 'old', 'terms', 'skip', 'reset', 'visualize', 'view', 'replay', 'log', 'run'],
],
'bundle' => [
'subcommands' => ['create', 'verify', 'list-heads', 'unbundle'],
],
'maintenance' => [
'subcommands' => ['run', 'start', 'stop', 'register', 'unregister'],
],
'notes' => [
'subcommands' => ['list', 'add', 'copy', 'append', 'edit', 'show', 'merge', 'remove', 'prune', 'get-ref'],
],
'sparse-checkout' => [
'subcommands' => ['init', 'list', 'set', 'add', 'reapply', 'disable', 'check-rules'],
],
'stash' => [
'subcommands' => ['list', 'show', 'drop', 'pop', 'apply', 'branch', 'push', 'save', 'clear', 'create', 'store'],
],
'submodule' => [
'subcommand_prefixes' => ['--quiet'],
'subcommands' => ['add', 'status', 'init', 'deinit', 'update', 'set-branch', 'set-url', 'summary', 'foreach', 'sync', 'absorbgitdirs'],
],
'worktree' => [
'subcommands' => ['add', 'list', 'lock', 'move', 'prune', 'remove', 'repair', 'unlock'],
],
'reflog' => [
'subcommands' => ['show', 'expire', 'delete', 'exists'],
],
'remote' => [
'subcommands' => ['add', 'rename', 'remove', 'set-head', 'set-branches', 'get-url', 'set-url', 'show', 'prune', 'update'],
],
'p4' => [
'subcommands' => ['clone', 'sync', 'rebase', 'submit'],
],
'commit-graph' => [
'subcommands' => ['verify', 'write'],
],
'credential' => [
'subcommands' => ['fill', 'approve', 'reject'],
],
'hook' => [
'subcommands' => ['run'],
],
],
];
use Aybarsm\Laravel\Support\Enums\ProcessReturnType;
$git = git();
$repo = $git->repo(); // Returns the default pre-defined repo
// or you can directly reach the repo
// $repo = gitRepo('default');
if ($repo->isReady() && $repo->isDirty()){
// arguments accepts strings or cli type arrays like arg, --arg=value, -arg value or -arg
$repo->commit(
args: [
'-a',
'-m' => '"v1.0.0"'
]
)
// Git and GitRepo concretes are already uses Laravel's Conditionable trait however chaining made easier with pre-defined whenSuccessful and whenFailed methods.
->whenSuccessful(
callback: fn ($repoInstance) => $repoInstance->tag('v1.0.0'),
default: function ($repoInstance) {
Log::info('Git Repo Command Error', (array)$repoInstance->result(ProcessReturnType::ALL_OUTPUT));
return $repoInstance;
}
)
->whenSuccessful(
callback: fn ($repoInstance) => $repoInstance->push('origin v1.0.0'),
default: function ($repoInstance) {
Log::info('Git Repo Command Error', (array)$repoInstance->result(ProcessReturnType::ALL_OUTPUT));
return $repoInstance;
}
);
}
// You can easily create individual GitRepo instances by
$newRepo = GitRepo::make('someName', '/some/path');
bash
php artisan vendor:publish --provider="Aybarsm\Laravel\Git\GitServiceProvider" --tag=config