feat(core): Add support for multiple registries in the publish process
This commit is contained in:
parent
f3d641d1c1
commit
819c1dca0f
@ -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
|
||||||
|
|
||||||
|
@ -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.'
|
||||||
}
|
}
|
||||||
|
@ -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}`
|
||||||
|
);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user