Compare commits

..

16 Commits

Author SHA1 Message Date
Pavel Shevaev c8a1167544 Adding --dry-run option to composer_vendor_push task and also making it possible to specify exact new version of a package
Publish PHP Package / docker (push) Successful in 7s Details
2025-02-25 13:20:28 +03:00
Pavel Shevaev c703ffd95b Adding basic support for UPM packages into composer_vendor_push
Publish PHP Package / docker (push) Successful in 5s Details
2024-09-26 18:25:57 +03:00
Pavel Shevaev 8ae4cff800 Using more robust git repository check
Publish PHP Package / docker (push) Successful in 5s Details
2024-08-13 10:57:55 +03:00
wrenge 6a23fc97fd composer status versions
Publish PHP Package / docker (push) Successful in 8s Details
2024-05-03 10:42:36 +03:00
Pavel Shevaev c465c09f4b Добавить .gitea/workflows/build_composer.yaml
Publish PHP Package / docker (push) Successful in 5s Details
2024-02-13 12:50:42 +03:00
Pavel Shevaev 2cc6dae273 Optionaly running 'composer update <package>' in case composer.lock entry wasn't update after composer_vendor_push 2024-02-13 12:19:08 +03:00
Pavel Shevaev 58b958f088 Getting rid of code duplication, migrating to COMPOSER_RUN env.variable 2023-10-24 23:21:07 +03:00
Pavel Shevaev 23174277ac Extracting composer_run(..) function 2023-10-24 21:33:29 +03:00
Pavel Shevaev c79c39e2bb Изменил(а) на 'composer.json' 2023-10-24 18:25:50 +03:00
Pavel Shevaev e13a6638fc Tweaking composer autoload 2023-10-24 17:33:40 +03:00
Pavel Shevaev 472a574460 Adding composer_reset task 2023-10-23 18:15:37 +03:00
Pavel Shevaev 7dd3825424 Adding deps_update alias for composer_update 2023-10-23 18:08:23 +03:00
Pavel Shevaev eb182cce0b Adding composer_update task which will eventually replace deps_update and a package responsible for it 2023-10-23 18:05:10 +03:00
Pavel Shevaev 9bbb133e2a Изменил(а) на 'composer.json' 2023-10-23 15:33:23 +03:00
Pavel Shevaev 307e82769c Изменил(а) на 'composer.json' 2023-10-23 15:31:44 +03:00
Pavel Shevaev 7d5c3e4b04 Fixing paths related issue 2023-10-23 15:25:10 +03:00
3 changed files with 156 additions and 44 deletions

View File

@ -0,0 +1,28 @@
name: Publish PHP Package
on:
push:
tags:
- 'v*'
jobs:
docker:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- name: Get tag name
run: echo "TAG=${GITHUB_REF#refs/*/}" >> $GITHUB_ENV
- name: zip and send
run: |
ls -la
apt-get update -y
apt-get install -y zip
cd ../
zip -r ${{ gitea.event.repository.name }}.zip ${{ gitea.event.repository.name }} -x '*.git*'
curl -v \
--user composer-pbl:${{ secrets.COMPOSER_PSWD }} \
--upload-file ${{ gitea.event.repository.name }}.zip \
https://git.bit5.ru/api/packages/bit/composer?version=${{ env.TAG }}

View File

@ -2,49 +2,55 @@
namespace taskman;
use Exception;
task('composer', function($args) {
$files = glob(__DIR__ . '/../composer/composer-*.phar');
$PHAR = basename($files[0]);
$cmd = "cd " . __DIR__ . "/../composer/ && ";
if(PHP_OS_FAMILY === 'Darwin')
{
$cmd .= "DYLD_LIBRARY_PATH='" . getenv("DYLD_LIBRARY_PATH") . "' " .
"PHP_INI_SCAN_DIR='" . getenv("PHP_INI_SCAN_DIR") . "' ";
$cmd .= PHP_BINARY . " -c '". getenv("PHP_INI") . "' ";
$ext_dir = realpath(ini_get('extension_dir'));
$cmd .= " -d extension_dir='$ext_dir' ";
}
else
$cmd .= PHP_BINARY . ' ';
$cmd .= "$PHAR " . implode(' ', $args);
shell($cmd);
task('composer_update', ['alias' => 'deps_update'], function()
{
composer_update(true);
});
task('composer_vendor_push', function($args) {
task('composer_reset', function()
{
global $GAME_ROOT;
echo "Going to reset composer package manager...\n";
are_you_sure();
ensure_rm("$GAME_ROOT/composer/vendor/");
ensure_rm("$GAME_ROOT/composer/composer.last");
});
task('composer', function(array $args) {
composer_run($args);
});
task('composer_vendor_push', function(array $args) {
$usage = "Usage: ./gamectl composer_vendor_push <path/to/repo> <commit message> [^[^[^]]]\n";
$dry_run = arg_opt($args, '--dry-run', false);
arg_opt_check_no_trailing($args);
if(count($args) < 2)
throw new Exception($usage);
$force_new_tag = '';
$up_mode = 1;
if(count($args) > 2)
{
if($args[2] === '^')
$tmp_arg = array_pop($args);
if($tmp_arg === '^')
$up_mode = 1;
else if($args[2] === '^^')
else if($tmp_arg === '^^')
$up_mode = 2;
else if($args[2] === '^^^')
else if($tmp_arg === '^^^')
$up_mode = 3;
else
throw new Exception("Invalid up mode: {$args[2]} (supported ^, ^^ and ^^^)");
$force_new_tag = $tmp_arg;
}
$relpath = $args[0];
$commit_msg = $args[1];
$relpath = array_shift($args);
$commit_msg = array_shift($args);
$repo = realpath("composer" .DIRECTORY_SEPARATOR. "vendor" .DIRECTORY_SEPARATOR. $relpath) ?: realpath($relpath);
if(!$repo)
@ -52,7 +58,7 @@ task('composer_vendor_push', function($args) {
echo "Detected folder: '$repo'\n";
if(!git_is_repo($repo))
if(!git_is_repo($repo, true))
throw new Exception("'$repo' is not a valid Git repo!\n");
echo "It's a valid Git repo\n";
@ -64,13 +70,63 @@ task('composer_vendor_push', function($args) {
echo "========\n";
$last_remote_tag = get_git_last_remote_tag($repo);
if($last_remote_tag === false)
throw new Exception("Could not retrieve last remote tag");
echo "The last remote Git tag: $last_remote_tag\n";
$last_remote_version = GitVersion::parse($last_remote_tag);
$last_remote_version->bump($up_mode);
echo "New version expected to be: {$last_remote_version->encode()}\n";
if(empty($force_new_tag))
{
$last_remote_version = GitVersion::parse($last_remote_tag);
$last_remote_version->bump($up_mode);
$new_tag = $last_remote_version->encode();
}
else
$new_tag = $force_new_tag;
are_you_sure();
echo "Commit message: {$commit_msg}\n";
echo "New version expected to be: {$new_tag}\n";
if($dry_run === false)
are_you_sure();
$is_upm = file_exists("$repo/package.json");
if($is_upm)
{
echo "This looks like an UPM package, let's update the package.json?\n";
if(are_you_sure_ask())
{
if(!function_exists('taskman\upm_get_package_info'))
{
echo "Can't proceed, composer 'bit/taskman_upm' package is missing\n";
exit(1);
}
$upm_info = upm_get_package_info($repo);
if(!isset($upm_info['name']))
throw new Exception("'name' is not present in package.json");
if(!isset($upm_info['version']))
throw new Exception("'version' is not present in package.json");
$upm_version = $upm_info['version'];
echo "Current package.json version is: {$upm_version}\n";
$upm_new_version = ltrim($new_tag, 'v');
echo "New package.json expected to be: {$upm_new_version}\n";
if($dry_run === false)
{
are_you_sure();
$upm_info['version'] = $upm_new_version;
upm_set_package_info($repo, $upm_info);
}
}
}
if($dry_run !== false)
{
echo "Dry run is done.\n";
return;
}
git_do($repo, 'add .');
git_do($repo, "commit -am \"$commit_msg\"", $commit_output);
@ -96,9 +152,14 @@ task('composer_vendor_push', function($args) {
$last_tag = _get_last_version_tag($tags);
echo "Last tag: $last_tag\n";
$last_version = GitVersion::parse($last_tag);
$last_version->bump($up_mode);
$new_tag = $last_version->encode();
if(empty($force_new_tag))
{
$last_version = GitVersion::parse($last_tag);
$last_version->bump($up_mode);
$new_tag = $last_version->encode();
}
else
$new_tag = $force_new_tag;
echo "New tag: $new_tag\n";
@ -112,7 +173,13 @@ task('composer_vendor_push', function($args) {
git_do($repo, 'push --tags');
git_do($repo, 'rev-parse HEAD', $output);
composer_try_update_lock_entry($relpath, trim($output[0]), $new_tag);
if(composer_try_update_lock_entry($relpath, trim($output[0]), $new_tag))
return;
echo "composer.lock file was not updated, run 'composer update $relpath'?\n";
are_you_sure();
composer_run(['update', $relpath]);
});
task('composer_vendor_status', function(array $args) {
@ -140,7 +207,11 @@ task('composer_vendor_status', function(array $args) {
if($status)
{
$package = str_replace(normalize_path("$GAME_ROOT/composer/vendor/"), '', normalize_path($item));
echo "==== Vendor package '$package' changes:\n";
$last_remote_tag = get_git_last_remote_tag($item);
echo "==== Vendor package '$package'[$last_remote_tag] changes";
if(is_file($item . '/package.json'))
echo " (UPM package?)";
echo ":\n";
echo implode("\n", $status) . "\n";
}
}
@ -148,7 +219,6 @@ task('composer_vendor_status', function(array $args) {
});
function composer_try_update_lock_entry($package, $rev, $new_tag)
{
global $GAME_ROOT;
@ -191,3 +261,19 @@ function composer_try_update_lock_entry($package, $rev, $new_tag)
return $changed;
}
function composer_run(array $args)
{
global $GAME_ROOT;
putenv('COMPOSER_RUN='.implode(' ', $args));
include("$GAME_ROOT/composer/update.php");
}
//NOTE: keeping this function for BC
function composer_update($update = false)
{
if($update)
composer_run(['update']);
else
composer_run(['install']);
}

View File

@ -1,11 +1,9 @@
{
"name": "bit/taskman_composer",
"description": "taskman composer utils",
"homepage": "https://git.bit5.ru/composer/taskman_composer",
"homepage": "https://git.bit5.ru/bit/taskman_composer",
"require": {
"php": ">=7.4"
},
"autoload": {
"classmap": ["composer.inc.php"]
"php": ">=7.4",
"bit/taskman_git" : "^v1.0.0"
}
}