2 Commits

Author SHA1 Message Date
a656e3e040 1.3.0
Some checks failed
Default (tags) / security (push) Failing after 3s
Default (tags) / test (push) Failing after 2s
Default (tags) / release (push) Has been skipped
Default (tags) / metadata (push) Has been skipped
2024-10-21 16:01:08 +02:00
819c1dca0f feat(core): Add support for multiple registries in the publish process 2024-10-21 16:01:08 +02:00
4 changed files with 29 additions and 6 deletions

View File

@ -1,5 +1,12 @@
# Changelog # Changelog
## 2024-10-21 - 1.3.0 - feat(core)
Add support for multiple registries in the publish process
- Updated the PublishModule class to handle multiple registries for publishing.
- Refactored the handling of tspublish.json by incorporating it into the PublishModule options.
- Implemented logic to parse registry access level and apply it during publication.
## 2024-10-21 - 1.2.4 - fix(publishmodule) ## 2024-10-21 - 1.2.4 - fix(publishmodule)
Fix syntax errors and improve formatting in classes.publishmodule.ts Fix syntax errors and improve formatting in classes.publishmodule.ts

View File

@ -1,6 +1,6 @@
{ {
"name": "@git.zone/tspublish", "name": "@git.zone/tspublish",
"version": "1.2.4", "version": "1.3.0",
"private": false, "private": false,
"description": "A tool to publish multiple, concise, and small packages from monorepos, specifically for TypeScript projects within a git environment.", "description": "A tool to publish multiple, concise, and small packages from monorepos, specifically for TypeScript projects within a git environment.",
"main": "dist_ts/index.js", "main": "dist_ts/index.js",

View File

@ -3,6 +3,6 @@
*/ */
export const commitinfo = { export const commitinfo = {
name: '@git.zone/tspublish', name: '@git.zone/tspublish',
version: '1.2.4', version: '1.3.0',
description: 'A tool to publish multiple, concise, and small packages from monorepos, specifically for TypeScript projects within a git environment.' description: 'A tool to publish multiple, concise, and small packages from monorepos, specifically for TypeScript projects within a git environment.'
} }

View File

@ -2,10 +2,17 @@ import * as plugins from './plugins.js';
import * as paths from './paths.js'; import * as paths from './paths.js';
import { logger } from './logging.js'; import { logger } from './logging.js';
export interface ITsPublishJson {
name: string;
dependencies: string[];
registries: string[];
}
export interface IPublishModuleOptions { export interface IPublishModuleOptions {
monoRepoDir: string; monoRepoDir: string;
packageSubFolder: string; packageSubFolder: string;
packageSubFolderFullPath?: string; packageSubFolderFullPath?: string;
tsPublishJson?: ITsPublishJson;
publishModDirFullPath?: string; publishModDirFullPath?: string;
name?: string; name?: string;
version?: string; version?: string;
@ -28,7 +35,7 @@ export class PublishModule {
if (!this.options.packageSubFolder.startsWith('ts')) { if (!this.options.packageSubFolder.startsWith('ts')) {
throw new Error('subFolder must start with "ts"'); throw new Error('subFolder must start with "ts"');
} }
const jsonData = plugins.smartfile.fs.toObjectSync( this.options.tsPublishJson = plugins.smartfile.fs.toObjectSync(
plugins.path.join(this.options.packageSubFolderFullPath, 'tspublish.json') plugins.path.join(this.options.packageSubFolderFullPath, 'tspublish.json')
); );
const monoRepoPackageJson = JSON.parse( const monoRepoPackageJson = JSON.parse(
@ -38,13 +45,13 @@ export class PublishModule {
...this.options.dependencies, ...this.options.dependencies,
...(() => { ...(() => {
const resultDependencies = {}; const resultDependencies = {};
for (const dependency of jsonData.dependencies) { for (const dependency of this.options.tsPublishJson.dependencies) {
resultDependencies[dependency] = monoRepoPackageJson.dependencies[dependency]; resultDependencies[dependency] = monoRepoPackageJson.dependencies[dependency];
} }
return resultDependencies; return resultDependencies;
})(), })(),
}; };
this.options.name = this.options.name || jsonData.name; this.options.name = this.options.name || this.options.tsPublishJson.name;
this.options.version = monoRepoPackageJson.version; this.options.version = monoRepoPackageJson.version;
// now that we have a name and version, lets check if there is already a package under the same name and version. // now that we have a name and version, lets check if there is already a package under the same name and version.
@ -137,6 +144,15 @@ export class PublishModule {
const smartshellInstance = new plugins.smartshell.Smartshell({ const smartshellInstance = new plugins.smartshell.Smartshell({
executor: 'bash', executor: 'bash',
}); });
await smartshellInstance.exec(`cd ${this.options.publishModDirFullPath} && pnpm publish --no-git-checks`); for (const registry of this.options.tsPublishJson.registries) {
const registryArray = registry.split(':');
const registryUrl = registryArray[0];
const registryAccessLevel = registryArray[1];
await smartshellInstance.exec(
`cd ${this.options.publishModDirFullPath} && pnpm publish ${
registryAccessLevel === 'public' ? '--access public' : ''
} --no-git-checks --registry https://${registryUrl}`
);
}
} }
} }