
* feat: ✨ add tax-classes-fetcher * refactor: ♻️ add "byId" suffix to crud-settings & remove upsert * feat: ✨ add updateMany method to CrudSettingsManager * feat: ✨ add avatax & taxjar tax-code-map-repository * refactor: 🚚 move to tax-code directory * feat: ✨ add getTaxCodes methods to provider clients * refactor: ♻️ extract taxClass and taxCode schema * refactor: 🚚 tax-code-map -> tax-code-match * feat: ✨ add taxjar-tax-code.service * feat: ✨ add avatax-tax-code.service * feat: ✨ add taxClass to graphql fragment * feat: ✨ use tax codes in calculate taxes * fix: 🐛 undefined tax code bug & add tests * build: 👷 add changeset * Update avatax-tax-code-mapper.ts * feat: ✨ add routers & get rid of adapters & mappers * refactor: ♻️ logger location -> name * refactor: ♻️ clean up & rephrase logs * refactor: ♻️ remove __typename from query * docs: 💡 make comments about tax codes more informative * refactor: ♻️ use resolveOptionalOrThrow on tax code description * refactor: ♻️ rename tax-codes -> tax-classes, move and rename tax-code-schema * refactor: 🚚 ctx -> authData * refactor: 🚚 createUrqlClientFromCtx -> createUrqlClientFromAuthdata * refactor: ♻️ dont spread ctx * docs: 💡 add comment about fallback tax code * refactor: ♻️ remove ..ctx * fix: 🐛 use createGraphQLClient * feat: tax code matcher ui (#658) * feat: ✨ use tax codes in calculate taxes * feat: ✨ add getTaxCodes methods to provider clients * feat: ✨ add matcher tables * feat: ✨ add log errors middleware * fix: 🔊 fix misleading logs * fix: 🐛 ctx appToken bug * feat: ✨ add Select override with wrapping label * feat: ✨ pre-select match * docs: 💡 add comments about first connection * docs: 💡 add comment about redirect * refactor: 🔥 duplicate file * feat: ✨ add AppCard to tables * feat: ✨ add _error to breadcrumbs exceptions * fix: 🐛 value not set on data * feat: 🥅 add error for no channels configured * fix: 🐛 replace update with upsert * refactor: 🚚 channel-configuration-settings to repository * fix: 🐛 updating a channel configuration * fix: 🧪 fix wrong mock * fix: 🐛 duplicating configs * Update cool-turtles-reflect.md
55 lines
1.7 KiB
TypeScript
55 lines
1.7 KiB
TypeScript
import { SettingsManager } from "@saleor/app-sdk/settings-manager";
|
|
import { Logger, createLogger } from "../../src/lib/logger";
|
|
import { TaxChannelsPrivateMetadataManagerV1 } from "./tax-channels-metadata-manager-v1";
|
|
import { TaxChannelsPrivateMetadataManagerV2 } from "./tax-channels-metadata-manager-v2";
|
|
import { TaxChannelsTransformV1toV2 } from "./tax-channels-transform-v1-to-v2";
|
|
|
|
export class TaxChannelsV1toV2MigrationManager {
|
|
private logger: Logger;
|
|
constructor(
|
|
private metadataManager: SettingsManager,
|
|
private saleorApiUrl: string,
|
|
private options: { mode: "report" | "migrate" } = { mode: "migrate" }
|
|
) {
|
|
this.logger = createLogger({
|
|
name: "TaxChannelsV1toV2MigrationManager",
|
|
});
|
|
}
|
|
|
|
async migrateIfNeeded() {
|
|
const taxChannelsManagerV1 = new TaxChannelsPrivateMetadataManagerV1(
|
|
this.metadataManager,
|
|
this.saleorApiUrl
|
|
);
|
|
|
|
const taxChannelsManagerV2 = new TaxChannelsPrivateMetadataManagerV2(
|
|
this.metadataManager,
|
|
this.saleorApiUrl
|
|
);
|
|
|
|
const currentConfig = await taxChannelsManagerV2.getConfig();
|
|
|
|
if (currentConfig) {
|
|
this.logger.info("Migration is not necessary, we have current config.");
|
|
return currentConfig;
|
|
}
|
|
|
|
const previousChannelConfig = await taxChannelsManagerV1.getConfig();
|
|
|
|
if (!previousChannelConfig) {
|
|
this.logger.info("Previous config not found. Migration not possible.");
|
|
return;
|
|
}
|
|
|
|
this.logger.info("Previous config found. Migrating...");
|
|
|
|
const transformer = new TaxChannelsTransformV1toV2();
|
|
const nextConfig = transformer.transform(previousChannelConfig);
|
|
|
|
if (this.options.mode === "migrate") {
|
|
await taxChannelsManagerV2.setConfig(nextConfig);
|
|
}
|
|
|
|
return nextConfig;
|
|
}
|
|
}
|