@cravery/core 0.0.7 → 0.0.9
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/config/collections.d.ts +5 -0
- package/dist/config/collections.d.ts.map +1 -1
- package/dist/config/collections.js +5 -0
- package/dist/config/collections.js.map +1 -1
- package/dist/config/common.js +1 -1
- package/dist/config/index.d.ts +1 -0
- package/dist/config/index.d.ts.map +1 -1
- package/dist/config/index.js +1 -0
- package/dist/config/index.js.map +1 -1
- package/dist/config/limits.d.ts +8 -0
- package/dist/config/limits.d.ts.map +1 -0
- package/dist/config/limits.js +36 -0
- package/dist/config/limits.js.map +1 -0
- package/dist/lib/ai/flow.d.ts +8 -8
- package/dist/lib/api.d.ts +1 -1
- package/dist/lib/api.d.ts.map +1 -1
- package/dist/lib/api.js +2 -2
- package/dist/lib/api.js.map +1 -1
- package/dist/lib/errors/index.d.ts +11 -2
- package/dist/lib/errors/index.d.ts.map +1 -1
- package/dist/lib/errors/index.js +31 -4
- package/dist/lib/errors/index.js.map +1 -1
- package/dist/lib/index.d.ts +1 -0
- package/dist/lib/index.d.ts.map +1 -1
- package/dist/lib/index.js +1 -0
- package/dist/lib/index.js.map +1 -1
- package/dist/lib/repository/equipment.repository.d.ts +15 -0
- package/dist/lib/repository/equipment.repository.d.ts.map +1 -0
- package/dist/lib/repository/equipment.repository.js +65 -0
- package/dist/lib/repository/equipment.repository.js.map +1 -0
- package/dist/lib/repository/factory.d.ts +10 -0
- package/dist/lib/repository/factory.d.ts.map +1 -1
- package/dist/lib/repository/factory.js +15 -0
- package/dist/lib/repository/factory.js.map +1 -1
- package/dist/lib/repository/index.d.ts +5 -0
- package/dist/lib/repository/index.d.ts.map +1 -1
- package/dist/lib/repository/index.js +5 -0
- package/dist/lib/repository/index.js.map +1 -1
- package/dist/lib/repository/ingredient.repository.d.ts +15 -0
- package/dist/lib/repository/ingredient.repository.d.ts.map +1 -0
- package/dist/lib/repository/ingredient.repository.js +65 -0
- package/dist/lib/repository/ingredient.repository.js.map +1 -0
- package/dist/lib/repository/recipe-queue.repository.d.ts +10 -0
- package/dist/lib/repository/recipe-queue.repository.d.ts.map +1 -0
- package/dist/lib/repository/recipe-queue.repository.js +37 -0
- package/dist/lib/repository/recipe-queue.repository.js.map +1 -0
- package/dist/lib/repository/recipe.repository.d.ts +10 -0
- package/dist/lib/repository/recipe.repository.d.ts.map +1 -0
- package/dist/lib/repository/recipe.repository.js +40 -0
- package/dist/lib/repository/recipe.repository.js.map +1 -0
- package/dist/lib/repository/report.repository.d.ts +15 -0
- package/dist/lib/repository/report.repository.d.ts.map +1 -0
- package/dist/lib/repository/report.repository.js +47 -0
- package/dist/lib/repository/report.repository.js.map +1 -0
- package/dist/lib/usage/index.d.ts +2 -0
- package/dist/lib/usage/index.d.ts.map +1 -0
- package/dist/lib/usage/index.js +18 -0
- package/dist/lib/usage/index.js.map +1 -0
- package/dist/lib/usage/usage.service.d.ts +28 -0
- package/dist/lib/usage/usage.service.d.ts.map +1 -0
- package/dist/lib/usage/usage.service.js +131 -0
- package/dist/lib/usage/usage.service.js.map +1 -0
- package/dist/lib/utils/index.d.ts +1 -0
- package/dist/lib/utils/index.d.ts.map +1 -1
- package/dist/lib/utils/index.js +1 -0
- package/dist/lib/utils/index.js.map +1 -1
- package/dist/lib/utils/sanitize.d.ts +2 -2
- package/dist/lib/utils/sanitize.d.ts.map +1 -1
- package/dist/lib/utils/slug.d.ts +13 -0
- package/dist/lib/utils/slug.d.ts.map +1 -0
- package/dist/lib/utils/slug.js +33 -0
- package/dist/lib/utils/slug.js.map +1 -0
- package/dist/types/ai/filters.d.ts +27 -78
- package/dist/types/ai/filters.d.ts.map +1 -1
- package/dist/types/ai/filters.js +8 -8
- package/dist/types/ai/filters.js.map +1 -1
- package/dist/types/ai/flow.d.ts +323 -0
- package/dist/types/ai/flow.d.ts.map +1 -0
- package/dist/types/ai/flow.js +65 -0
- package/dist/types/ai/flow.js.map +1 -0
- package/dist/types/ai/index.d.ts +1 -0
- package/dist/types/ai/index.d.ts.map +1 -1
- package/dist/types/ai/index.js +1 -0
- package/dist/types/ai/index.js.map +1 -1
- package/dist/types/ai/recipe.d.ts +207 -141
- package/dist/types/ai/recipe.d.ts.map +1 -1
- package/dist/types/ai/recipe.js +14 -14
- package/dist/types/ai/recipe.js.map +1 -1
- package/dist/types/ai/translation.d.ts +89 -7
- package/dist/types/ai/translation.d.ts.map +1 -1
- package/dist/types/ai/translation.js +8 -8
- package/dist/types/ai/translation.js.map +1 -1
- package/dist/types/asset.d.ts +33 -0
- package/dist/types/asset.d.ts.map +1 -0
- package/dist/types/asset.js +18 -0
- package/dist/types/asset.js.map +1 -0
- package/dist/types/enums/allergen.d.ts +2 -16
- package/dist/types/enums/allergen.d.ts.map +1 -1
- package/dist/types/enums/allergen.js +2 -2
- package/dist/types/enums/allergen.js.map +1 -1
- package/dist/types/enums/cuisine.d.ts +2 -36
- package/dist/types/enums/cuisine.d.ts.map +1 -1
- package/dist/types/enums/cuisine.js +2 -2
- package/dist/types/enums/cuisine.js.map +1 -1
- package/dist/types/enums/dietary_tag.d.ts +2 -18
- package/dist/types/enums/dietary_tag.d.ts.map +1 -1
- package/dist/types/enums/dietary_tag.js +2 -2
- package/dist/types/enums/dietary_tag.js.map +1 -1
- package/dist/types/enums/difficulty.d.ts +2 -7
- package/dist/types/enums/difficulty.d.ts.map +1 -1
- package/dist/types/enums/difficulty.js +2 -2
- package/dist/types/enums/difficulty.js.map +1 -1
- package/dist/types/enums/image_type.d.ts +2 -5
- package/dist/types/enums/image_type.d.ts.map +1 -1
- package/dist/types/enums/image_type.js +2 -2
- package/dist/types/enums/image_type.js.map +1 -1
- package/dist/types/enums/locale.d.ts +2 -8
- package/dist/types/enums/locale.d.ts.map +1 -1
- package/dist/types/enums/locale.js +2 -2
- package/dist/types/enums/locale.js.map +1 -1
- package/dist/types/enums/meal_type.d.ts +2 -11
- package/dist/types/enums/meal_type.d.ts.map +1 -1
- package/dist/types/enums/meal_type.js +2 -2
- package/dist/types/enums/meal_type.js.map +1 -1
- package/dist/types/enums/moderation_status.d.ts +2 -6
- package/dist/types/enums/moderation_status.d.ts.map +1 -1
- package/dist/types/enums/moderation_status.js +2 -2
- package/dist/types/enums/moderation_status.js.map +1 -1
- package/dist/types/enums/priority.d.ts +2 -6
- package/dist/types/enums/priority.d.ts.map +1 -1
- package/dist/types/enums/priority.js +2 -2
- package/dist/types/enums/priority.js.map +1 -1
- package/dist/types/enums/profile_status.d.ts +2 -7
- package/dist/types/enums/profile_status.d.ts.map +1 -1
- package/dist/types/enums/profile_status.js +2 -2
- package/dist/types/enums/profile_status.js.map +1 -1
- package/dist/types/enums/recipe_source.d.ts +2 -7
- package/dist/types/enums/recipe_source.d.ts.map +1 -1
- package/dist/types/enums/recipe_source.js +2 -2
- package/dist/types/enums/recipe_source.js.map +1 -1
- package/dist/types/enums/recipe_status.d.ts +2 -10
- package/dist/types/enums/recipe_status.d.ts.map +1 -1
- package/dist/types/enums/recipe_status.js +2 -2
- package/dist/types/enums/recipe_status.js.map +1 -1
- package/dist/types/enums/role.d.ts +2 -8
- package/dist/types/enums/role.d.ts.map +1 -1
- package/dist/types/enums/role.js +2 -2
- package/dist/types/enums/role.js.map +1 -1
- package/dist/types/enums/severity.d.ts +2 -6
- package/dist/types/enums/severity.d.ts.map +1 -1
- package/dist/types/enums/severity.js +2 -2
- package/dist/types/enums/severity.js.map +1 -1
- package/dist/types/enums/spiciness.d.ts +2 -7
- package/dist/types/enums/spiciness.d.ts.map +1 -1
- package/dist/types/enums/spiciness.js +2 -2
- package/dist/types/enums/spiciness.js.map +1 -1
- package/dist/types/enums/subscription_tier.d.ts +2 -6
- package/dist/types/enums/subscription_tier.d.ts.map +1 -1
- package/dist/types/enums/subscription_tier.js +2 -2
- package/dist/types/enums/subscription_tier.js.map +1 -1
- package/dist/types/enums/suggestion_category.d.ts +2 -8
- package/dist/types/enums/suggestion_category.d.ts.map +1 -1
- package/dist/types/enums/suggestion_category.js +2 -2
- package/dist/types/enums/suggestion_category.js.map +1 -1
- package/dist/types/enums/temperature_unit.d.ts +2 -5
- package/dist/types/enums/temperature_unit.d.ts.map +1 -1
- package/dist/types/enums/temperature_unit.js +2 -2
- package/dist/types/enums/temperature_unit.js.map +1 -1
- package/dist/types/enums/unit.d.ts +2 -40
- package/dist/types/enums/unit.d.ts.map +1 -1
- package/dist/types/enums/unit.js +2 -2
- package/dist/types/enums/unit.js.map +1 -1
- package/dist/types/enums/url_type.d.ts +2 -10
- package/dist/types/enums/url_type.d.ts.map +1 -1
- package/dist/types/enums/url_type.js +2 -2
- package/dist/types/enums/url_type.js.map +1 -1
- package/dist/types/enums/user_status.d.ts +2 -7
- package/dist/types/enums/user_status.d.ts.map +1 -1
- package/dist/types/enums/user_status.js +2 -2
- package/dist/types/enums/user_status.js.map +1 -1
- package/dist/types/iam/profile.d.ts +57 -13
- package/dist/types/iam/profile.d.ts.map +1 -1
- package/dist/types/iam/profile.js +18 -18
- package/dist/types/iam/profile.js.map +1 -1
- package/dist/types/iam/subscription.d.ts +71 -33
- package/dist/types/iam/subscription.d.ts.map +1 -1
- package/dist/types/iam/subscription.js +13 -13
- package/dist/types/iam/subscription.js.map +1 -1
- package/dist/types/iam/user.d.ts +46 -20
- package/dist/types/iam/user.d.ts.map +1 -1
- package/dist/types/iam/user.js +10 -10
- package/dist/types/iam/user.js.map +1 -1
- package/dist/types/index.d.ts +2 -0
- package/dist/types/index.d.ts.map +1 -1
- package/dist/types/index.js +2 -0
- package/dist/types/index.js.map +1 -1
- package/dist/types/moderation.d.ts +136 -62
- package/dist/types/moderation.d.ts.map +1 -1
- package/dist/types/moderation.js +27 -26
- package/dist/types/moderation.js.map +1 -1
- package/dist/types/recipe/equipment.d.ts +28 -4
- package/dist/types/recipe/equipment.d.ts.map +1 -1
- package/dist/types/recipe/equipment.js +9 -9
- package/dist/types/recipe/equipment.js.map +1 -1
- package/dist/types/recipe/ingredient.d.ts +132 -166
- package/dist/types/recipe/ingredient.d.ts.map +1 -1
- package/dist/types/recipe/ingredient.js +21 -21
- package/dist/types/recipe/ingredient.js.map +1 -1
- package/dist/types/recipe/instruction.d.ts +56 -14
- package/dist/types/recipe/instruction.d.ts.map +1 -1
- package/dist/types/recipe/instruction.js +8 -8
- package/dist/types/recipe/instruction.js.map +1 -1
- package/dist/types/recipe/nutrition.d.ts +22 -2
- package/dist/types/recipe/nutrition.d.ts.map +1 -1
- package/dist/types/recipe/nutrition.js +11 -11
- package/dist/types/recipe/nutrition.js.map +1 -1
- package/dist/types/recipe/recipe.d.ts +452 -352
- package/dist/types/recipe/recipe.d.ts.map +1 -1
- package/dist/types/recipe/recipe.js +53 -53
- package/dist/types/recipe/recipe.js.map +1 -1
- package/dist/types/recipe/temperature.d.ts +9 -6
- package/dist/types/recipe/temperature.d.ts.map +1 -1
- package/dist/types/recipe/temperature.js +3 -3
- package/dist/types/recipe/temperature.js.map +1 -1
- package/dist/types/report.d.ts +127 -0
- package/dist/types/report.d.ts.map +1 -0
- package/dist/types/report.js +61 -0
- package/dist/types/report.js.map +1 -0
- package/dist/types/repository.d.ts +2 -5
- package/dist/types/repository.d.ts.map +1 -1
- package/dist/types/repository.js +2 -2
- package/dist/types/repository.js.map +1 -1
- package/dist/types/settings.d.ts +75 -109
- package/dist/types/settings.d.ts.map +1 -1
- package/dist/types/settings.js +16 -16
- package/dist/types/settings.js.map +1 -1
- package/package.json +2 -6
- package/src/config/collections.ts +5 -0
- package/src/config/common.ts +1 -1
- package/src/config/index.ts +1 -0
- package/src/config/limits.ts +41 -0
- package/src/lib/api.ts +1 -1
- package/src/lib/errors/index.ts +30 -3
- package/src/lib/index.ts +1 -0
- package/src/lib/repository/equipment.repository.ts +93 -0
- package/src/lib/repository/factory.ts +15 -0
- package/src/lib/repository/index.ts +5 -0
- package/src/lib/repository/ingredient.repository.ts +93 -0
- package/src/lib/repository/recipe-queue.repository.ts +49 -0
- package/src/lib/repository/recipe.repository.ts +51 -0
- package/src/lib/repository/report.repository.ts +85 -0
- package/src/lib/usage/index.ts +1 -0
- package/src/lib/usage/usage.service.ts +189 -0
- package/src/lib/utils/index.ts +1 -0
- package/src/lib/utils/sanitize.ts +1 -1
- package/src/lib/utils/slug.ts +33 -0
- package/src/types/ai/filters.ts +1 -1
- package/src/types/ai/flow.ts +78 -0
- package/src/types/ai/index.ts +1 -0
- package/src/types/ai/recipe.ts +1 -1
- package/src/types/ai/translation.ts +1 -1
- package/src/types/asset.ts +19 -0
- package/src/types/enums/allergen.ts +1 -1
- package/src/types/enums/cuisine.ts +1 -1
- package/src/types/enums/dietary_tag.ts +1 -1
- package/src/types/enums/difficulty.ts +1 -1
- package/src/types/enums/image_type.ts +1 -1
- package/src/types/enums/locale.ts +1 -1
- package/src/types/enums/meal_type.ts +1 -1
- package/src/types/enums/moderation_status.ts +1 -1
- package/src/types/enums/priority.ts +1 -1
- package/src/types/enums/profile_status.ts +1 -1
- package/src/types/enums/recipe_source.ts +1 -1
- package/src/types/enums/recipe_status.ts +1 -1
- package/src/types/enums/role.ts +1 -1
- package/src/types/enums/severity.ts +1 -1
- package/src/types/enums/spiciness.ts +1 -1
- package/src/types/enums/subscription_tier.ts +1 -1
- package/src/types/enums/suggestion_category.ts +1 -1
- package/src/types/enums/temperature_unit.ts +1 -1
- package/src/types/enums/unit.ts +1 -1
- package/src/types/enums/url_type.ts +1 -1
- package/src/types/enums/user_status.ts +1 -1
- package/src/types/iam/profile.ts +16 -4
- package/src/types/iam/subscription.ts +1 -1
- package/src/types/iam/user.ts +16 -4
- package/src/types/index.ts +2 -0
- package/src/types/moderation.ts +38 -10
- package/src/types/recipe/equipment.ts +1 -1
- package/src/types/recipe/ingredient.ts +1 -1
- package/src/types/recipe/instruction.ts +1 -1
- package/src/types/recipe/nutrition.ts +1 -1
- package/src/types/recipe/recipe.ts +39 -3
- package/src/types/recipe/temperature.ts +1 -1
- package/src/types/report.ts +90 -0
- package/src/types/repository.ts +1 -1
- package/src/types/settings.ts +1 -1
- package/dist/config/credits.d.ts +0 -2
- package/dist/config/credits.d.ts.map +0 -1
- package/dist/config/credits.js +0 -5
- package/dist/config/credits.js.map +0 -1
- package/dist/enums/allergen.d.ts +0 -19
- package/dist/enums/allergen.d.ts.map +0 -1
- package/dist/enums/allergen.js +0 -21
- package/dist/enums/allergen.js.map +0 -1
- package/dist/enums/cuisine.d.ts +0 -39
- package/dist/enums/cuisine.d.ts.map +0 -1
- package/dist/enums/cuisine.js +0 -41
- package/dist/enums/cuisine.js.map +0 -1
- package/dist/enums/dietary_tag.d.ts +0 -21
- package/dist/enums/dietary_tag.d.ts.map +0 -1
- package/dist/enums/dietary_tag.js +0 -23
- package/dist/enums/dietary_tag.js.map +0 -1
- package/dist/enums/difficulty.d.ts +0 -10
- package/dist/enums/difficulty.d.ts.map +0 -1
- package/dist/enums/difficulty.js +0 -12
- package/dist/enums/difficulty.js.map +0 -1
- package/dist/enums/image_type.d.ts +0 -8
- package/dist/enums/image_type.d.ts.map +0 -1
- package/dist/enums/image_type.js +0 -7
- package/dist/enums/image_type.js.map +0 -1
- package/dist/enums/index.d.ts +0 -22
- package/dist/enums/index.d.ts.map +0 -1
- package/dist/enums/index.js +0 -38
- package/dist/enums/index.js.map +0 -1
- package/dist/enums/locale.d.ts +0 -11
- package/dist/enums/locale.d.ts.map +0 -1
- package/dist/enums/locale.js +0 -7
- package/dist/enums/locale.js.map +0 -1
- package/dist/enums/meal_type.d.ts +0 -14
- package/dist/enums/meal_type.d.ts.map +0 -1
- package/dist/enums/meal_type.js +0 -16
- package/dist/enums/meal_type.js.map +0 -1
- package/dist/enums/moderation_status.d.ts +0 -9
- package/dist/enums/moderation_status.d.ts.map +0 -1
- package/dist/enums/moderation_status.js +0 -11
- package/dist/enums/moderation_status.js.map +0 -1
- package/dist/enums/priority.d.ts +0 -9
- package/dist/enums/priority.d.ts.map +0 -1
- package/dist/enums/priority.js +0 -7
- package/dist/enums/priority.js.map +0 -1
- package/dist/enums/profile_status.d.ts +0 -10
- package/dist/enums/profile_status.d.ts.map +0 -1
- package/dist/enums/profile_status.js +0 -12
- package/dist/enums/profile_status.js.map +0 -1
- package/dist/enums/recipe_source.d.ts +0 -10
- package/dist/enums/recipe_source.d.ts.map +0 -1
- package/dist/enums/recipe_source.js +0 -7
- package/dist/enums/recipe_source.js.map +0 -1
- package/dist/enums/recipe_status.d.ts +0 -10
- package/dist/enums/recipe_status.d.ts.map +0 -1
- package/dist/enums/recipe_status.js +0 -12
- package/dist/enums/recipe_status.js.map +0 -1
- package/dist/enums/role.d.ts +0 -11
- package/dist/enums/role.d.ts.map +0 -1
- package/dist/enums/role.js +0 -13
- package/dist/enums/role.js.map +0 -1
- package/dist/enums/severity.d.ts +0 -9
- package/dist/enums/severity.d.ts.map +0 -1
- package/dist/enums/severity.js +0 -7
- package/dist/enums/severity.js.map +0 -1
- package/dist/enums/spiciness.d.ts +0 -10
- package/dist/enums/spiciness.d.ts.map +0 -1
- package/dist/enums/spiciness.js +0 -7
- package/dist/enums/spiciness.js.map +0 -1
- package/dist/enums/status.d.ts +0 -11
- package/dist/enums/status.d.ts.map +0 -1
- package/dist/enums/status.js +0 -13
- package/dist/enums/status.js.map +0 -1
- package/dist/enums/subscription_tier.d.ts +0 -8
- package/dist/enums/subscription_tier.d.ts.map +0 -1
- package/dist/enums/subscription_tier.js +0 -6
- package/dist/enums/subscription_tier.js.map +0 -1
- package/dist/enums/suggestion_category.d.ts +0 -11
- package/dist/enums/suggestion_category.d.ts.map +0 -1
- package/dist/enums/suggestion_category.js +0 -13
- package/dist/enums/suggestion_category.js.map +0 -1
- package/dist/enums/temperature_unit.d.ts +0 -8
- package/dist/enums/temperature_unit.d.ts.map +0 -1
- package/dist/enums/temperature_unit.js +0 -7
- package/dist/enums/temperature_unit.js.map +0 -1
- package/dist/enums/unit.d.ts +0 -43
- package/dist/enums/unit.d.ts.map +0 -1
- package/dist/enums/unit.js +0 -53
- package/dist/enums/unit.js.map +0 -1
- package/dist/enums/url_type.d.ts +0 -13
- package/dist/enums/url_type.d.ts.map +0 -1
- package/dist/enums/url_type.js +0 -15
- package/dist/enums/url_type.js.map +0 -1
- package/dist/enums/user_status.d.ts +0 -10
- package/dist/enums/user_status.d.ts.map +0 -1
- package/dist/enums/user_status.js +0 -12
- package/dist/enums/user_status.js.map +0 -1
- package/dist/lib/cost.d.ts +0 -22
- package/dist/lib/cost.d.ts.map +0 -1
- package/dist/lib/cost.js +0 -45
- package/dist/lib/cost.js.map +0 -1
- package/dist/lib/embedding.d.ts +0 -4
- package/dist/lib/embedding.d.ts.map +0 -1
- package/dist/lib/embedding.js +0 -48
- package/dist/lib/embedding.js.map +0 -1
- package/dist/lib/flow.d.ts +0 -53
- package/dist/lib/flow.d.ts.map +0 -1
- package/dist/lib/flow.js +0 -60
- package/dist/lib/flow.js.map +0 -1
- package/dist/lib/genkit.d.ts +0 -4
- package/dist/lib/genkit.d.ts.map +0 -1
- package/dist/lib/genkit.js +0 -16
- package/dist/lib/genkit.js.map +0 -1
- package/dist/lib/image.d.ts +0 -7
- package/dist/lib/image.d.ts.map +0 -1
- package/dist/lib/image.js +0 -24
- package/dist/lib/image.js.map +0 -1
- package/dist/types/enums/status.d.ts +0 -11
- package/dist/types/enums/status.d.ts.map +0 -1
- package/dist/types/enums/status.js +0 -13
- package/dist/types/enums/status.js.map +0 -1
- package/dist/types/equipment.d.ts +0 -20
- package/dist/types/equipment.d.ts.map +0 -1
- package/dist/types/equipment.js +0 -16
- package/dist/types/equipment.js.map +0 -1
- package/dist/types/error.d.ts +0 -14
- package/dist/types/error.d.ts.map +0 -1
- package/dist/types/error.js +0 -40
- package/dist/types/error.js.map +0 -1
- package/dist/types/ingredient.d.ts +0 -209
- package/dist/types/ingredient.d.ts.map +0 -1
- package/dist/types/ingredient.js +0 -33
- package/dist/types/ingredient.js.map +0 -1
- package/dist/types/instruction.d.ts +0 -32
- package/dist/types/instruction.d.ts.map +0 -1
- package/dist/types/instruction.js +0 -16
- package/dist/types/instruction.js.map +0 -1
- package/dist/types/nutrition.d.ts +0 -18
- package/dist/types/nutrition.d.ts.map +0 -1
- package/dist/types/nutrition.js +0 -20
- package/dist/types/nutrition.js.map +0 -1
- package/dist/types/profile.d.ts +0 -30
- package/dist/types/profile.d.ts.map +0 -1
- package/dist/types/profile.js +0 -26
- package/dist/types/profile.js.map +0 -1
- package/dist/types/recipe.d.ts +0 -447
- package/dist/types/recipe.d.ts.map +0 -1
- package/dist/types/recipe.js +0 -82
- package/dist/types/recipe.js.map +0 -1
- package/dist/types/subscription.d.ts +0 -15
- package/dist/types/subscription.d.ts.map +0 -1
- package/dist/types/subscription.js +0 -14
- package/dist/types/subscription.js.map +0 -1
- package/dist/types/temperature.d.ts +0 -10
- package/dist/types/temperature.d.ts.map +0 -1
- package/dist/types/temperature.js +0 -10
- package/dist/types/temperature.js.map +0 -1
- package/dist/types/user.d.ts +0 -26
- package/dist/types/user.d.ts.map +0 -1
- package/dist/types/user.js +0 -17
- package/dist/types/user.js.map +0 -1
- package/src/types/enums/status.ts +0 -11
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.IngredientRepository = void 0;
|
|
4
|
+
const firestore_1 = require("firebase-admin/firestore");
|
|
5
|
+
const firestore_repository_1 = require("./firestore.repository");
|
|
6
|
+
const asset_1 = require("../../types/asset");
|
|
7
|
+
const collections_1 = require("../../config/collections");
|
|
8
|
+
const errors_1 = require("./errors");
|
|
9
|
+
class IngredientRepository extends firestore_repository_1.FirestoreRepository {
|
|
10
|
+
constructor(firestore) {
|
|
11
|
+
super(firestore, collections_1.Collections.Ingredients, {
|
|
12
|
+
enableTimestamps: true,
|
|
13
|
+
enableSoftDelete: false,
|
|
14
|
+
validateOnWrite: true,
|
|
15
|
+
});
|
|
16
|
+
}
|
|
17
|
+
validate(data) {
|
|
18
|
+
const result = asset_1.AssetSchema.partial().safeParse(data);
|
|
19
|
+
if (!result.success) {
|
|
20
|
+
throw new errors_1.RepositoryError(errors_1.RepositoryErrorCode.VALIDATION_ERROR, "Ingredient validation failed", { errors: result.error.issues });
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
async findBySlug(slug) {
|
|
24
|
+
return this.findById(slug);
|
|
25
|
+
}
|
|
26
|
+
async slugExists(slug) {
|
|
27
|
+
return this.exists(slug);
|
|
28
|
+
}
|
|
29
|
+
async getLocale(slug, locale) {
|
|
30
|
+
const docRef = this.collection.doc(slug).collection("locales").doc(locale);
|
|
31
|
+
const doc = await docRef.get();
|
|
32
|
+
if (!doc.exists)
|
|
33
|
+
return null;
|
|
34
|
+
return Object.assign({ locale }, doc.data());
|
|
35
|
+
}
|
|
36
|
+
async setLocale(slug, locale, data) {
|
|
37
|
+
const docRef = this.collection.doc(slug).collection("locales").doc(locale);
|
|
38
|
+
await docRef.set(Object.assign({ locale }, data));
|
|
39
|
+
}
|
|
40
|
+
async getAllLocales(slug) {
|
|
41
|
+
const snapshot = await this.collection
|
|
42
|
+
.doc(slug)
|
|
43
|
+
.collection("locales")
|
|
44
|
+
.get();
|
|
45
|
+
return snapshot.docs.map((doc) => (Object.assign({ locale: doc.id }, doc.data())));
|
|
46
|
+
}
|
|
47
|
+
async createWithLocale(slug, imageUrl, locale, localeData) {
|
|
48
|
+
const now = firestore_1.Timestamp.now();
|
|
49
|
+
const batch = this.firestore.batch();
|
|
50
|
+
const docRef = this.collection.doc(slug);
|
|
51
|
+
const assetData = {
|
|
52
|
+
id: slug,
|
|
53
|
+
imageUrl,
|
|
54
|
+
createdAt: now,
|
|
55
|
+
updatedAt: now,
|
|
56
|
+
};
|
|
57
|
+
batch.set(docRef, assetData);
|
|
58
|
+
const localeRef = docRef.collection("locales").doc(locale);
|
|
59
|
+
batch.set(localeRef, Object.assign({ locale }, localeData));
|
|
60
|
+
await batch.commit();
|
|
61
|
+
return assetData;
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
exports.IngredientRepository = IngredientRepository;
|
|
65
|
+
//# sourceMappingURL=ingredient.repository.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ingredient.repository.js","sourceRoot":"","sources":["../../../src/lib/repository/ingredient.repository.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { Firestore } from "firebase-admin/firestore";
|
|
2
|
+
import { FirestoreRepository } from "./firestore.repository";
|
|
3
|
+
import type { RecipeMeta } from "../../types/recipe";
|
|
4
|
+
export declare class RecipeQueueRepository extends FirestoreRepository<RecipeMeta> {
|
|
5
|
+
constructor(firestore: Firestore);
|
|
6
|
+
protected validate(data: Partial<RecipeMeta>): void;
|
|
7
|
+
findBySourceUrl(sourceUrl: string): Promise<RecipeMeta | null>;
|
|
8
|
+
findBySourceUrlAndUser(sourceUrl: string, userId: string): Promise<RecipeMeta | null>;
|
|
9
|
+
}
|
|
10
|
+
//# sourceMappingURL=recipe-queue.repository.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"recipe-queue.repository.d.ts","sourceRoot":"","sources":["../../../src/lib/repository/recipe-queue.repository.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,0BAA0B,CAAC;AACrD,OAAO,EAAE,mBAAmB,EAAE,MAAM,wBAAwB,CAAC;AAC7D,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAC;AAKrD,qBAAa,qBAAsB,SAAQ,mBAAmB,CAAC,UAAU,CAAC;gBAC5D,SAAS,EAAE,SAAS;IAQhC,SAAS,CAAC,QAAQ,CAAC,IAAI,EAAE,OAAO,CAAC,UAAU,CAAC,GAAG,IAAI;IAW7C,eAAe,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,UAAU,GAAG,IAAI,CAAC;IAQ9D,sBAAsB,CAC1B,SAAS,EAAE,MAAM,EACjB,MAAM,EAAE,MAAM,GACb,OAAO,CAAC,UAAU,GAAG,IAAI,CAAC;CAU9B"}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.RecipeQueueRepository = void 0;
|
|
4
|
+
const firestore_repository_1 = require("./firestore.repository");
|
|
5
|
+
const recipe_1 = require("../../types/recipe");
|
|
6
|
+
const collections_1 = require("../../config/collections");
|
|
7
|
+
const errors_1 = require("./errors");
|
|
8
|
+
class RecipeQueueRepository extends firestore_repository_1.FirestoreRepository {
|
|
9
|
+
constructor(firestore) {
|
|
10
|
+
super(firestore, collections_1.Collections.RecipeQueue, {
|
|
11
|
+
enableTimestamps: true,
|
|
12
|
+
enableSoftDelete: false,
|
|
13
|
+
validateOnWrite: true,
|
|
14
|
+
});
|
|
15
|
+
}
|
|
16
|
+
validate(data) {
|
|
17
|
+
const result = recipe_1.RecipeMetaSchema.partial().safeParse(data);
|
|
18
|
+
if (!result.success) {
|
|
19
|
+
throw new errors_1.RepositoryError(errors_1.RepositoryErrorCode.VALIDATION_ERROR, "Recipe queue validation failed", { errors: result.error.issues });
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
async findBySourceUrl(sourceUrl) {
|
|
23
|
+
var _a;
|
|
24
|
+
const results = await this.findWhere([{ field: "sourceUrl", op: "==", value: sourceUrl }], { limit: 1 });
|
|
25
|
+
return (_a = results[0]) !== null && _a !== void 0 ? _a : null;
|
|
26
|
+
}
|
|
27
|
+
async findBySourceUrlAndUser(sourceUrl, userId) {
|
|
28
|
+
var _a;
|
|
29
|
+
const results = await this.findWhere([
|
|
30
|
+
{ field: "sourceUrl", op: "==", value: sourceUrl },
|
|
31
|
+
{ field: "createdBy", op: "==", value: userId },
|
|
32
|
+
], { limit: 1 });
|
|
33
|
+
return (_a = results[0]) !== null && _a !== void 0 ? _a : null;
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
exports.RecipeQueueRepository = RecipeQueueRepository;
|
|
37
|
+
//# sourceMappingURL=recipe-queue.repository.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"recipe-queue.repository.js","sourceRoot":"","sources":["../../../src/lib/repository/recipe-queue.repository.ts"],"names":[],"mappings":";;;AACA,iEAA6D;AAE7D,+CAAsD;AACtD,0DAAuD;AACvD,qCAAgE;AAEhE,MAAa,qBAAsB,SAAQ,0CAA+B;IACxE,YAAY,SAAoB;QAC9B,KAAK,CAAC,SAAS,EAAE,yBAAW,CAAC,WAAW,EAAE;YACxC,gBAAgB,EAAE,IAAI;YACtB,gBAAgB,EAAE,KAAK;YACvB,eAAe,EAAE,IAAI;SACtB,CAAC,CAAC;IACL,CAAC;IAES,QAAQ,CAAC,IAAyB;QAC1C,MAAM,MAAM,GAAG,yBAAgB,CAAC,OAAO,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAC1D,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;YACpB,MAAM,IAAI,wBAAe,CACvB,4BAAmB,CAAC,gBAAgB,EACpC,gCAAgC,EAChC,EAAE,MAAM,EAAE,MAAM,CAAC,KAAK,CAAC,MAAM,EAAE,CAChC,CAAC;QACJ,CAAC;IACH,CAAC;IAED,KAAK,CAAC,eAAe,CAAC,SAAiB;;QACrC,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,SAAS,CAClC,CAAC,EAAE,KAAK,EAAE,WAAW,EAAE,EAAE,EAAE,IAAI,EAAE,KAAK,EAAE,SAAS,EAAE,CAAC,EACpD,EAAE,KAAK,EAAE,CAAC,EAAE,CACb,CAAC;QACF,OAAO,MAAA,OAAO,CAAC,CAAC,CAAC,mCAAI,IAAI,CAAC;IAC5B,CAAC;IAED,KAAK,CAAC,sBAAsB,CAC1B,SAAiB,EACjB,MAAc;;QAEd,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,SAAS,CAClC;YACE,EAAE,KAAK,EAAE,WAAW,EAAE,EAAE,EAAE,IAAI,EAAE,KAAK,EAAE,SAAS,EAAE;YAClD,EAAE,KAAK,EAAE,WAAW,EAAE,EAAE,EAAE,IAAI,EAAE,KAAK,EAAE,MAAM,EAAE;SAChD,EACD,EAAE,KAAK,EAAE,CAAC,EAAE,CACb,CAAC;QACF,OAAO,MAAA,OAAO,CAAC,CAAC,CAAC,mCAAI,IAAI,CAAC;IAC5B,CAAC;CACF;AAzCD,sDAyCC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { Firestore } from "firebase-admin/firestore";
|
|
2
|
+
import { FirestoreRepository } from "./firestore.repository";
|
|
3
|
+
import type { RecipeMeta } from "../../types/recipe";
|
|
4
|
+
export declare class RecipeRepository extends FirestoreRepository<RecipeMeta> {
|
|
5
|
+
constructor(firestore: Firestore);
|
|
6
|
+
protected validate(data: Partial<RecipeMeta>): void;
|
|
7
|
+
findBySourceUrl(sourceUrl: string): Promise<RecipeMeta | null>;
|
|
8
|
+
hardDelete(id: string): Promise<void>;
|
|
9
|
+
}
|
|
10
|
+
//# sourceMappingURL=recipe.repository.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"recipe.repository.d.ts","sourceRoot":"","sources":["../../../src/lib/repository/recipe.repository.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,0BAA0B,CAAC;AACrD,OAAO,EAAE,mBAAmB,EAAE,MAAM,wBAAwB,CAAC;AAC7D,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAC;AAKrD,qBAAa,gBAAiB,SAAQ,mBAAmB,CAAC,UAAU,CAAC;gBACvD,SAAS,EAAE,SAAS;IAQhC,SAAS,CAAC,QAAQ,CAAC,IAAI,EAAE,OAAO,CAAC,UAAU,CAAC,GAAG,IAAI;IAW7C,eAAe,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,UAAU,GAAG,IAAI,CAAC;IAQ9D,UAAU,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;CAe5C"}
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.RecipeRepository = void 0;
|
|
4
|
+
const firestore_repository_1 = require("./firestore.repository");
|
|
5
|
+
const recipe_1 = require("../../types/recipe");
|
|
6
|
+
const collections_1 = require("../../config/collections");
|
|
7
|
+
const errors_1 = require("./errors");
|
|
8
|
+
class RecipeRepository extends firestore_repository_1.FirestoreRepository {
|
|
9
|
+
constructor(firestore) {
|
|
10
|
+
super(firestore, collections_1.Collections.Recipes, {
|
|
11
|
+
enableTimestamps: true,
|
|
12
|
+
enableSoftDelete: true,
|
|
13
|
+
validateOnWrite: true,
|
|
14
|
+
});
|
|
15
|
+
}
|
|
16
|
+
validate(data) {
|
|
17
|
+
const result = recipe_1.RecipeMetaSchema.partial().safeParse(data);
|
|
18
|
+
if (!result.success) {
|
|
19
|
+
throw new errors_1.RepositoryError(errors_1.RepositoryErrorCode.VALIDATION_ERROR, "Recipe validation failed", { errors: result.error.issues });
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
async findBySourceUrl(sourceUrl) {
|
|
23
|
+
var _a;
|
|
24
|
+
const results = await this.findWhere([{ field: "sourceUrl", op: "==", value: sourceUrl }], { limit: 1 });
|
|
25
|
+
return (_a = results[0]) !== null && _a !== void 0 ? _a : null;
|
|
26
|
+
}
|
|
27
|
+
async hardDelete(id) {
|
|
28
|
+
const docRef = this.collection.doc(id);
|
|
29
|
+
const contentRef = docRef.collection("content");
|
|
30
|
+
const batch = this.firestore.batch();
|
|
31
|
+
const contentDocs = await contentRef.listDocuments();
|
|
32
|
+
for (const doc of contentDocs) {
|
|
33
|
+
batch.delete(doc);
|
|
34
|
+
}
|
|
35
|
+
batch.delete(docRef);
|
|
36
|
+
await batch.commit();
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
exports.RecipeRepository = RecipeRepository;
|
|
40
|
+
//# sourceMappingURL=recipe.repository.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"recipe.repository.js","sourceRoot":"","sources":["../../../src/lib/repository/recipe.repository.ts"],"names":[],"mappings":";;;AACA,iEAA6D;AAE7D,+CAAsD;AACtD,0DAAuD;AACvD,qCAAgE;AAEhE,MAAa,gBAAiB,SAAQ,0CAA+B;IACnE,YAAY,SAAoB;QAC9B,KAAK,CAAC,SAAS,EAAE,yBAAW,CAAC,OAAO,EAAE;YACpC,gBAAgB,EAAE,IAAI;YACtB,gBAAgB,EAAE,IAAI;YACtB,eAAe,EAAE,IAAI;SACtB,CAAC,CAAC;IACL,CAAC;IAES,QAAQ,CAAC,IAAyB;QAC1C,MAAM,MAAM,GAAG,yBAAgB,CAAC,OAAO,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAC1D,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;YACpB,MAAM,IAAI,wBAAe,CACvB,4BAAmB,CAAC,gBAAgB,EACpC,0BAA0B,EAC1B,EAAE,MAAM,EAAE,MAAM,CAAC,KAAK,CAAC,MAAM,EAAE,CAChC,CAAC;QACJ,CAAC;IACH,CAAC;IAED,KAAK,CAAC,eAAe,CAAC,SAAiB;;QACrC,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,SAAS,CAClC,CAAC,EAAE,KAAK,EAAE,WAAW,EAAE,EAAE,EAAE,IAAI,EAAE,KAAK,EAAE,SAAS,EAAE,CAAC,EACpD,EAAE,KAAK,EAAE,CAAC,EAAE,CACb,CAAC;QACF,OAAO,MAAA,OAAO,CAAC,CAAC,CAAC,mCAAI,IAAI,CAAC;IAC5B,CAAC;IAED,KAAK,CAAC,UAAU,CAAC,EAAU;QACzB,MAAM,MAAM,GAAG,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;QACvC,MAAM,UAAU,GAAG,MAAM,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC;QAEhD,MAAM,KAAK,GAAG,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,CAAC;QAErC,MAAM,WAAW,GAAG,MAAM,UAAU,CAAC,aAAa,EAAE,CAAC;QACrD,KAAK,MAAM,GAAG,IAAI,WAAW,EAAE,CAAC;YAC9B,KAAK,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;QACpB,CAAC;QAED,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;QAErB,MAAM,KAAK,CAAC,MAAM,EAAE,CAAC;IACvB,CAAC;CACF;AA3CD,4CA2CC"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { Firestore } from "firebase-admin/firestore";
|
|
2
|
+
import { FirestoreRepository } from "./firestore.repository";
|
|
3
|
+
import type { Report, ReportStatus, ReportType } from "../../types/report";
|
|
4
|
+
import type { QueryOptions } from "../../types/repository";
|
|
5
|
+
export declare class ReportRepository extends FirestoreRepository<Report> {
|
|
6
|
+
constructor(firestore: Firestore);
|
|
7
|
+
protected validate(data: Partial<Report>): void;
|
|
8
|
+
findByStatus(status: ReportStatus, options?: QueryOptions): Promise<Report[]>;
|
|
9
|
+
findByType(type: ReportType, options?: QueryOptions): Promise<Report[]>;
|
|
10
|
+
findByUserId(userId: string, options?: QueryOptions): Promise<Report[]>;
|
|
11
|
+
findByTargetId(targetId: string, options?: QueryOptions): Promise<Report[]>;
|
|
12
|
+
findPending(options?: QueryOptions): Promise<Report[]>;
|
|
13
|
+
countByUserInPeriod(userId: string, startDate: Date, endDate: Date): Promise<number>;
|
|
14
|
+
}
|
|
15
|
+
//# sourceMappingURL=report.repository.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"report.repository.d.ts","sourceRoot":"","sources":["../../../src/lib/repository/report.repository.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,0BAA0B,CAAC;AACrD,OAAO,EAAE,mBAAmB,EAAE,MAAM,wBAAwB,CAAC;AAC7D,OAAO,KAAK,EAAE,MAAM,EAAE,YAAY,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAC;AAI3E,OAAO,KAAK,EAAe,YAAY,EAAE,MAAM,wBAAwB,CAAC;AAExE,qBAAa,gBAAiB,SAAQ,mBAAmB,CAAC,MAAM,CAAC;gBACnD,SAAS,EAAE,SAAS;IAQhC,SAAS,CAAC,QAAQ,CAAC,IAAI,EAAE,OAAO,CAAC,MAAM,CAAC,GAAG,IAAI;IAWzC,YAAY,CAChB,MAAM,EAAE,YAAY,EACpB,OAAO,CAAC,EAAE,YAAY,GACrB,OAAO,CAAC,MAAM,EAAE,CAAC;IAOd,UAAU,CACd,IAAI,EAAE,UAAU,EAChB,OAAO,CAAC,EAAE,YAAY,GACrB,OAAO,CAAC,MAAM,EAAE,CAAC;IAOd,YAAY,CAChB,MAAM,EAAE,MAAM,EACd,OAAO,CAAC,EAAE,YAAY,GACrB,OAAO,CAAC,MAAM,EAAE,CAAC;IAOd,cAAc,CAClB,QAAQ,EAAE,MAAM,EAChB,OAAO,CAAC,EAAE,YAAY,GACrB,OAAO,CAAC,MAAM,EAAE,CAAC;IAOd,WAAW,CAAC,OAAO,CAAC,EAAE,YAAY,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC;IAItD,mBAAmB,CACvB,MAAM,EAAE,MAAM,EACd,SAAS,EAAE,IAAI,EACf,OAAO,EAAE,IAAI,GACZ,OAAO,CAAC,MAAM,CAAC;CAQnB"}
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ReportRepository = void 0;
|
|
4
|
+
const firestore_repository_1 = require("./firestore.repository");
|
|
5
|
+
const report_1 = require("../../types/report");
|
|
6
|
+
const collections_1 = require("../../config/collections");
|
|
7
|
+
const errors_1 = require("./errors");
|
|
8
|
+
class ReportRepository extends firestore_repository_1.FirestoreRepository {
|
|
9
|
+
constructor(firestore) {
|
|
10
|
+
super(firestore, collections_1.Collections.Reports, {
|
|
11
|
+
enableTimestamps: true,
|
|
12
|
+
enableSoftDelete: false,
|
|
13
|
+
validateOnWrite: true,
|
|
14
|
+
});
|
|
15
|
+
}
|
|
16
|
+
validate(data) {
|
|
17
|
+
const result = report_1.ReportSchema.partial().safeParse(data);
|
|
18
|
+
if (!result.success) {
|
|
19
|
+
throw new errors_1.RepositoryError(errors_1.RepositoryErrorCode.VALIDATION_ERROR, "Report validation failed", { errors: result.error.issues });
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
async findByStatus(status, options) {
|
|
23
|
+
return this.findWhere([{ field: "status", op: "==", value: status }], Object.assign({ orderBy: { field: "createdAt", direction: "desc" } }, options));
|
|
24
|
+
}
|
|
25
|
+
async findByType(type, options) {
|
|
26
|
+
return this.findWhere([{ field: "type", op: "==", value: type }], Object.assign({ orderBy: { field: "createdAt", direction: "desc" } }, options));
|
|
27
|
+
}
|
|
28
|
+
async findByUserId(userId, options) {
|
|
29
|
+
return this.findWhere([{ field: "userId", op: "==", value: userId }], Object.assign({ orderBy: { field: "createdAt", direction: "desc" } }, options));
|
|
30
|
+
}
|
|
31
|
+
async findByTargetId(targetId, options) {
|
|
32
|
+
return this.findWhere([{ field: "targetId", op: "==", value: targetId }], Object.assign({ orderBy: { field: "createdAt", direction: "desc" } }, options));
|
|
33
|
+
}
|
|
34
|
+
async findPending(options) {
|
|
35
|
+
return this.findByStatus("pending", options);
|
|
36
|
+
}
|
|
37
|
+
async countByUserInPeriod(userId, startDate, endDate) {
|
|
38
|
+
const clauses = [
|
|
39
|
+
{ field: "userId", op: "==", value: userId },
|
|
40
|
+
{ field: "createdAt", op: ">=", value: startDate },
|
|
41
|
+
{ field: "createdAt", op: "<=", value: endDate },
|
|
42
|
+
];
|
|
43
|
+
return this.count(clauses);
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
exports.ReportRepository = ReportRepository;
|
|
47
|
+
//# sourceMappingURL=report.repository.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"report.repository.js","sourceRoot":"","sources":["../../../src/lib/repository/report.repository.ts"],"names":[],"mappings":";;;AACA,iEAA6D;AAE7D,+CAAkD;AAClD,0DAAuD;AACvD,qCAAgE;AAGhE,MAAa,gBAAiB,SAAQ,0CAA2B;IAC/D,YAAY,SAAoB;QAC9B,KAAK,CAAC,SAAS,EAAE,yBAAW,CAAC,OAAO,EAAE;YACpC,gBAAgB,EAAE,IAAI;YACtB,gBAAgB,EAAE,KAAK;YACvB,eAAe,EAAE,IAAI;SACtB,CAAC,CAAC;IACL,CAAC;IAES,QAAQ,CAAC,IAAqB;QACtC,MAAM,MAAM,GAAG,qBAAY,CAAC,OAAO,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QACtD,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;YACpB,MAAM,IAAI,wBAAe,CACvB,4BAAmB,CAAC,gBAAgB,EACpC,0BAA0B,EAC1B,EAAE,MAAM,EAAE,MAAM,CAAC,KAAK,CAAC,MAAM,EAAE,CAChC,CAAC;QACJ,CAAC;IACH,CAAC;IAED,KAAK,CAAC,YAAY,CAChB,MAAoB,EACpB,OAAsB;QAEtB,OAAO,IAAI,CAAC,SAAS,CAAC,CAAC,EAAE,KAAK,EAAE,QAAQ,EAAE,EAAE,EAAE,IAAI,EAAE,KAAK,EAAE,MAAM,EAAE,CAAC,kBAClE,OAAO,EAAE,EAAE,KAAK,EAAE,WAAW,EAAE,SAAS,EAAE,MAAM,EAAE,IAC/C,OAAO,EACV,CAAC;IACL,CAAC;IAED,KAAK,CAAC,UAAU,CACd,IAAgB,EAChB,OAAsB;QAEtB,OAAO,IAAI,CAAC,SAAS,CAAC,CAAC,EAAE,KAAK,EAAE,MAAM,EAAE,EAAE,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC,kBAC9D,OAAO,EAAE,EAAE,KAAK,EAAE,WAAW,EAAE,SAAS,EAAE,MAAM,EAAE,IAC/C,OAAO,EACV,CAAC;IACL,CAAC;IAED,KAAK,CAAC,YAAY,CAChB,MAAc,EACd,OAAsB;QAEtB,OAAO,IAAI,CAAC,SAAS,CAAC,CAAC,EAAE,KAAK,EAAE,QAAQ,EAAE,EAAE,EAAE,IAAI,EAAE,KAAK,EAAE,MAAM,EAAE,CAAC,kBAClE,OAAO,EAAE,EAAE,KAAK,EAAE,WAAW,EAAE,SAAS,EAAE,MAAM,EAAE,IAC/C,OAAO,EACV,CAAC;IACL,CAAC;IAED,KAAK,CAAC,cAAc,CAClB,QAAgB,EAChB,OAAsB;QAEtB,OAAO,IAAI,CAAC,SAAS,CAAC,CAAC,EAAE,KAAK,EAAE,UAAU,EAAE,EAAE,EAAE,IAAI,EAAE,KAAK,EAAE,QAAQ,EAAE,CAAC,kBACtE,OAAO,EAAE,EAAE,KAAK,EAAE,WAAW,EAAE,SAAS,EAAE,MAAM,EAAE,IAC/C,OAAO,EACV,CAAC;IACL,CAAC;IAED,KAAK,CAAC,WAAW,CAAC,OAAsB;QACtC,OAAO,IAAI,CAAC,YAAY,CAAC,SAAS,EAAE,OAAO,CAAC,CAAC;IAC/C,CAAC;IAED,KAAK,CAAC,mBAAmB,CACvB,MAAc,EACd,SAAe,EACf,OAAa;QAEb,MAAM,OAAO,GAAkB;YAC7B,EAAE,KAAK,EAAE,QAAQ,EAAE,EAAE,EAAE,IAAI,EAAE,KAAK,EAAE,MAAM,EAAE;YAC5C,EAAE,KAAK,EAAE,WAAW,EAAE,EAAE,EAAE,IAAI,EAAE,KAAK,EAAE,SAAS,EAAE;YAClD,EAAE,KAAK,EAAE,WAAW,EAAE,EAAE,EAAE,IAAI,EAAE,KAAK,EAAE,OAAO,EAAE;SACjD,CAAC;QACF,OAAO,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;IAC7B,CAAC;CACF;AA5ED,4CA4EC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/lib/usage/index.ts"],"names":[],"mappings":"AAAA,cAAc,iBAAiB,CAAC"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./usage.service"), exports);
|
|
18
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/lib/usage/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,kDAAgC"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { Database } from "firebase-admin/database";
|
|
2
|
+
import type { SubscriptionTier } from "../../types/enums";
|
|
3
|
+
import { type UsageType } from "../../config/limits";
|
|
4
|
+
import { DailyLimitError, MonthlyLimitError } from "../errors";
|
|
5
|
+
export interface UsageCheckResult {
|
|
6
|
+
allowed: boolean;
|
|
7
|
+
dailyRemaining: number;
|
|
8
|
+
monthlyRemaining: number;
|
|
9
|
+
error?: DailyLimitError | MonthlyLimitError;
|
|
10
|
+
}
|
|
11
|
+
export declare class UsageService {
|
|
12
|
+
private readonly database;
|
|
13
|
+
constructor(database: Database);
|
|
14
|
+
private getDateString;
|
|
15
|
+
private getMonthString;
|
|
16
|
+
private getDailyRef;
|
|
17
|
+
private getMonthlyRef;
|
|
18
|
+
checkLimit(userId: string, type: UsageType, tier: SubscriptionTier): Promise<UsageCheckResult>;
|
|
19
|
+
increment(userId: string, type: UsageType): Promise<void>;
|
|
20
|
+
getUsage(userId: string, type: UsageType): Promise<{
|
|
21
|
+
daily: number;
|
|
22
|
+
monthly: number;
|
|
23
|
+
lifetime: number;
|
|
24
|
+
}>;
|
|
25
|
+
resetDaily(userId: string, type: UsageType): Promise<void>;
|
|
26
|
+
resetMonthly(userId: string, type: UsageType): Promise<void>;
|
|
27
|
+
}
|
|
28
|
+
//# sourceMappingURL=usage.service.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"usage.service.d.ts","sourceRoot":"","sources":["../../../src/lib/usage/usage.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,yBAAyB,CAAC;AACnD,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,mBAAmB,CAAC;AAC1D,OAAO,EAAe,KAAK,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAClE,OAAO,EAAE,eAAe,EAAE,iBAAiB,EAAE,MAAM,WAAW,CAAC;AAY/D,MAAM,WAAW,gBAAgB;IAC/B,OAAO,EAAE,OAAO,CAAC;IACjB,cAAc,EAAE,MAAM,CAAC;IACvB,gBAAgB,EAAE,MAAM,CAAC;IACzB,KAAK,CAAC,EAAE,eAAe,GAAG,iBAAiB,CAAC;CAC7C;AAED,qBAAa,YAAY;IACX,OAAO,CAAC,QAAQ,CAAC,QAAQ;gBAAR,QAAQ,EAAE,QAAQ;IAE/C,OAAO,CAAC,aAAa;IAIrB,OAAO,CAAC,cAAc;IAItB,OAAO,CAAC,WAAW;IAInB,OAAO,CAAC,aAAa;IAIf,UAAU,CACd,MAAM,EAAE,MAAM,EACd,IAAI,EAAE,SAAS,EACf,IAAI,EAAE,gBAAgB,GACrB,OAAO,CAAC,gBAAgB,CAAC;IAkEtB,SAAS,CAAC,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,SAAS,GAAG,OAAO,CAAC,IAAI,CAAC;IA6BzD,QAAQ,CACZ,MAAM,EAAE,MAAM,EACd,IAAI,EAAE,SAAS,GACd,OAAO,CAAC;QAAE,KAAK,EAAE,MAAM,CAAC;QAAC,OAAO,EAAE,MAAM,CAAC;QAAC,QAAQ,EAAE,MAAM,CAAA;KAAE,CAAC;IAoC1D,UAAU,CAAC,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,SAAS,GAAG,OAAO,CAAC,IAAI,CAAC;IAK1D,YAAY,CAAC,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,SAAS,GAAG,OAAO,CAAC,IAAI,CAAC;CAInE"}
|
|
@@ -0,0 +1,131 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.UsageService = void 0;
|
|
4
|
+
const limits_1 = require("../../config/limits");
|
|
5
|
+
const errors_1 = require("../errors");
|
|
6
|
+
class UsageService {
|
|
7
|
+
constructor(database) {
|
|
8
|
+
this.database = database;
|
|
9
|
+
}
|
|
10
|
+
getDateString() {
|
|
11
|
+
return new Date().toISOString().split("T")[0];
|
|
12
|
+
}
|
|
13
|
+
getMonthString() {
|
|
14
|
+
return new Date().toISOString().slice(0, 7);
|
|
15
|
+
}
|
|
16
|
+
getDailyRef(userId, type) {
|
|
17
|
+
return this.database.ref(`usage/${userId}/daily/${type}`);
|
|
18
|
+
}
|
|
19
|
+
getMonthlyRef(userId, type) {
|
|
20
|
+
return this.database.ref(`usage/${userId}/monthly/${type}`);
|
|
21
|
+
}
|
|
22
|
+
async checkLimit(userId, type, tier) {
|
|
23
|
+
const limits = limits_1.TIER_LIMITS[tier];
|
|
24
|
+
const dailyLimit = limits.daily[type];
|
|
25
|
+
const monthlyLimit = limits.monthly[type];
|
|
26
|
+
const today = this.getDateString();
|
|
27
|
+
const month = this.getMonthString();
|
|
28
|
+
const [dailySnapshot, monthlySnapshot] = await Promise.all([
|
|
29
|
+
this.getDailyRef(userId, type).get(),
|
|
30
|
+
this.getMonthlyRef(userId, type).get(),
|
|
31
|
+
]);
|
|
32
|
+
let dailyCount = 0;
|
|
33
|
+
let monthlyCount = 0;
|
|
34
|
+
if (dailySnapshot.exists()) {
|
|
35
|
+
const data = dailySnapshot.val();
|
|
36
|
+
if (data.date === today) {
|
|
37
|
+
dailyCount = data.count;
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
if (monthlySnapshot.exists()) {
|
|
41
|
+
const data = monthlySnapshot.val();
|
|
42
|
+
if (data.month === month) {
|
|
43
|
+
monthlyCount = data.count;
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
const dailyRemaining = dailyLimit === -1 ? Infinity : dailyLimit - dailyCount;
|
|
47
|
+
const monthlyRemaining = monthlyLimit === -1 ? Infinity : monthlyLimit - monthlyCount;
|
|
48
|
+
if (dailyLimit !== -1 && dailyCount >= dailyLimit) {
|
|
49
|
+
return {
|
|
50
|
+
allowed: false,
|
|
51
|
+
dailyRemaining: 0,
|
|
52
|
+
monthlyRemaining,
|
|
53
|
+
error: new errors_1.DailyLimitError(`Daily ${type} limit reached (${dailyLimit})`, { type, limit: dailyLimit, count: dailyCount }),
|
|
54
|
+
};
|
|
55
|
+
}
|
|
56
|
+
if (monthlyLimit !== -1 && monthlyCount >= monthlyLimit) {
|
|
57
|
+
return {
|
|
58
|
+
allowed: false,
|
|
59
|
+
dailyRemaining,
|
|
60
|
+
monthlyRemaining: 0,
|
|
61
|
+
error: new errors_1.MonthlyLimitError(`Monthly ${type} limit reached (${monthlyLimit})`, { type, limit: monthlyLimit, count: monthlyCount }),
|
|
62
|
+
};
|
|
63
|
+
}
|
|
64
|
+
return {
|
|
65
|
+
allowed: true,
|
|
66
|
+
dailyRemaining,
|
|
67
|
+
monthlyRemaining,
|
|
68
|
+
};
|
|
69
|
+
}
|
|
70
|
+
async increment(userId, type) {
|
|
71
|
+
const today = this.getDateString();
|
|
72
|
+
const month = this.getMonthString();
|
|
73
|
+
const dailyRef = this.getDailyRef(userId, type);
|
|
74
|
+
const monthlyRef = this.getMonthlyRef(userId, type);
|
|
75
|
+
const lifetimeRef = this.database.ref(`usage/${userId}/lifetime/total${type.charAt(0).toUpperCase() + type.slice(1)}s`);
|
|
76
|
+
await Promise.all([
|
|
77
|
+
dailyRef.transaction((current) => {
|
|
78
|
+
if (!current || current.date !== today) {
|
|
79
|
+
return { count: 1, date: today };
|
|
80
|
+
}
|
|
81
|
+
return { count: current.count + 1, date: today };
|
|
82
|
+
}),
|
|
83
|
+
monthlyRef.transaction((current) => {
|
|
84
|
+
if (!current || current.month !== month) {
|
|
85
|
+
return { count: 1, month };
|
|
86
|
+
}
|
|
87
|
+
return { count: current.count + 1, month };
|
|
88
|
+
}),
|
|
89
|
+
lifetimeRef.transaction((current) => {
|
|
90
|
+
return (current || 0) + 1;
|
|
91
|
+
}),
|
|
92
|
+
]);
|
|
93
|
+
}
|
|
94
|
+
async getUsage(userId, type) {
|
|
95
|
+
const today = this.getDateString();
|
|
96
|
+
const month = this.getMonthString();
|
|
97
|
+
const [dailySnapshot, monthlySnapshot, lifetimeSnapshot] = await Promise.all([
|
|
98
|
+
this.getDailyRef(userId, type).get(),
|
|
99
|
+
this.getMonthlyRef(userId, type).get(),
|
|
100
|
+
this.database
|
|
101
|
+
.ref(`usage/${userId}/lifetime/total${type.charAt(0).toUpperCase() + type.slice(1)}s`)
|
|
102
|
+
.get(),
|
|
103
|
+
]);
|
|
104
|
+
let daily = 0;
|
|
105
|
+
let monthly = 0;
|
|
106
|
+
const lifetime = lifetimeSnapshot.exists() ? lifetimeSnapshot.val() : 0;
|
|
107
|
+
if (dailySnapshot.exists()) {
|
|
108
|
+
const data = dailySnapshot.val();
|
|
109
|
+
if (data.date === today) {
|
|
110
|
+
daily = data.count;
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
if (monthlySnapshot.exists()) {
|
|
114
|
+
const data = monthlySnapshot.val();
|
|
115
|
+
if (data.month === month) {
|
|
116
|
+
monthly = data.count;
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
return { daily, monthly, lifetime };
|
|
120
|
+
}
|
|
121
|
+
async resetDaily(userId, type) {
|
|
122
|
+
const today = this.getDateString();
|
|
123
|
+
await this.getDailyRef(userId, type).set({ count: 0, date: today });
|
|
124
|
+
}
|
|
125
|
+
async resetMonthly(userId, type) {
|
|
126
|
+
const month = this.getMonthString();
|
|
127
|
+
await this.getMonthlyRef(userId, type).set({ count: 0, month });
|
|
128
|
+
}
|
|
129
|
+
}
|
|
130
|
+
exports.UsageService = UsageService;
|
|
131
|
+
//# sourceMappingURL=usage.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"usage.service.js","sourceRoot":"","sources":["../../../src/lib/usage/usage.service.ts"],"names":[],"mappings":";;;AAEA,gDAAkE;AAClE,sCAA+D;AAmB/D,MAAa,YAAY;IACvB,YAA6B,QAAkB;QAAlB,aAAQ,GAAR,QAAQ,CAAU;IAAG,CAAC;IAE3C,aAAa;QACnB,OAAO,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;IAChD,CAAC;IAEO,cAAc;QACpB,OAAO,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IAC9C,CAAC;IAEO,WAAW,CAAC,MAAc,EAAE,IAAe;QACjD,OAAO,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,SAAS,MAAM,UAAU,IAAI,EAAE,CAAC,CAAC;IAC5D,CAAC;IAEO,aAAa,CAAC,MAAc,EAAE,IAAe;QACnD,OAAO,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,SAAS,MAAM,YAAY,IAAI,EAAE,CAAC,CAAC;IAC9D,CAAC;IAED,KAAK,CAAC,UAAU,CACd,MAAc,EACd,IAAe,EACf,IAAsB;QAEtB,MAAM,MAAM,GAAG,oBAAW,CAAC,IAAI,CAAC,CAAC;QACjC,MAAM,UAAU,GAAG,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;QACtC,MAAM,YAAY,GAAG,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QAE1C,MAAM,KAAK,GAAG,IAAI,CAAC,aAAa,EAAE,CAAC;QACnC,MAAM,KAAK,GAAG,IAAI,CAAC,cAAc,EAAE,CAAC;QAEpC,MAAM,CAAC,aAAa,EAAE,eAAe,CAAC,GAAG,MAAM,OAAO,CAAC,GAAG,CAAC;YACzD,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC,GAAG,EAAE;YACpC,IAAI,CAAC,aAAa,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC,GAAG,EAAE;SACvC,CAAC,CAAC;QAEH,IAAI,UAAU,GAAG,CAAC,CAAC;QACnB,IAAI,YAAY,GAAG,CAAC,CAAC;QAErB,IAAI,aAAa,CAAC,MAAM,EAAE,EAAE,CAAC;YAC3B,MAAM,IAAI,GAAG,aAAa,CAAC,GAAG,EAAkB,CAAC;YACjD,IAAI,IAAI,CAAC,IAAI,KAAK,KAAK,EAAE,CAAC;gBACxB,UAAU,GAAG,IAAI,CAAC,KAAK,CAAC;YAC1B,CAAC;QACH,CAAC;QAED,IAAI,eAAe,CAAC,MAAM,EAAE,EAAE,CAAC;YAC7B,MAAM,IAAI,GAAG,eAAe,CAAC,GAAG,EAAoB,CAAC;YACrD,IAAI,IAAI,CAAC,KAAK,KAAK,KAAK,EAAE,CAAC;gBACzB,YAAY,GAAG,IAAI,CAAC,KAAK,CAAC;YAC5B,CAAC;QACH,CAAC;QAED,MAAM,cAAc,GAClB,UAAU,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,UAAU,GAAG,UAAU,CAAC;QACzD,MAAM,gBAAgB,GACpB,YAAY,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,YAAY,GAAG,YAAY,CAAC;QAE/D,IAAI,UAAU,KAAK,CAAC,CAAC,IAAI,UAAU,IAAI,UAAU,EAAE,CAAC;YAClD,OAAO;gBACL,OAAO,EAAE,KAAK;gBACd,cAAc,EAAE,CAAC;gBACjB,gBAAgB;gBAChB,KAAK,EAAE,IAAI,wBAAe,CACxB,SAAS,IAAI,mBAAmB,UAAU,GAAG,EAC7C,EAAE,IAAI,EAAE,KAAK,EAAE,UAAU,EAAE,KAAK,EAAE,UAAU,EAAE,CAC/C;aACF,CAAC;QACJ,CAAC;QAED,IAAI,YAAY,KAAK,CAAC,CAAC,IAAI,YAAY,IAAI,YAAY,EAAE,CAAC;YACxD,OAAO;gBACL,OAAO,EAAE,KAAK;gBACd,cAAc;gBACd,gBAAgB,EAAE,CAAC;gBACnB,KAAK,EAAE,IAAI,0BAAiB,CAC1B,WAAW,IAAI,mBAAmB,YAAY,GAAG,EACjD,EAAE,IAAI,EAAE,KAAK,EAAE,YAAY,EAAE,KAAK,EAAE,YAAY,EAAE,CACnD;aACF,CAAC;QACJ,CAAC;QAED,OAAO;YACL,OAAO,EAAE,IAAI;YACb,cAAc;YACd,gBAAgB;SACjB,CAAC;IACJ,CAAC;IAED,KAAK,CAAC,SAAS,CAAC,MAAc,EAAE,IAAe;QAC7C,MAAM,KAAK,GAAG,IAAI,CAAC,aAAa,EAAE,CAAC;QACnC,MAAM,KAAK,GAAG,IAAI,CAAC,cAAc,EAAE,CAAC;QAEpC,MAAM,QAAQ,GAAG,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;QAChD,MAAM,UAAU,GAAG,IAAI,CAAC,aAAa,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;QACpD,MAAM,WAAW,GAAG,IAAI,CAAC,QAAQ,CAAC,GAAG,CACnC,SAAS,MAAM,kBAAkB,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,GAAG,CACjF,CAAC;QAEF,MAAM,OAAO,CAAC,GAAG,CAAC;YAChB,QAAQ,CAAC,WAAW,CAAC,CAAC,OAA4B,EAAE,EAAE;gBACpD,IAAI,CAAC,OAAO,IAAI,OAAO,CAAC,IAAI,KAAK,KAAK,EAAE,CAAC;oBACvC,OAAO,EAAE,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC;gBACnC,CAAC;gBACD,OAAO,EAAE,KAAK,EAAE,OAAO,CAAC,KAAK,GAAG,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC;YACnD,CAAC,CAAC;YACF,UAAU,CAAC,WAAW,CAAC,CAAC,OAA8B,EAAE,EAAE;gBACxD,IAAI,CAAC,OAAO,IAAI,OAAO,CAAC,KAAK,KAAK,KAAK,EAAE,CAAC;oBACxC,OAAO,EAAE,KAAK,EAAE,CAAC,EAAE,KAAK,EAAE,CAAC;gBAC7B,CAAC;gBACD,OAAO,EAAE,KAAK,EAAE,OAAO,CAAC,KAAK,GAAG,CAAC,EAAE,KAAK,EAAE,CAAC;YAC7C,CAAC,CAAC;YACF,WAAW,CAAC,WAAW,CAAC,CAAC,OAAsB,EAAE,EAAE;gBACjD,OAAO,CAAC,OAAO,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC;YAC5B,CAAC,CAAC;SACH,CAAC,CAAC;IACL,CAAC;IAED,KAAK,CAAC,QAAQ,CACZ,MAAc,EACd,IAAe;QAEf,MAAM,KAAK,GAAG,IAAI,CAAC,aAAa,EAAE,CAAC;QACnC,MAAM,KAAK,GAAG,IAAI,CAAC,cAAc,EAAE,CAAC;QAEpC,MAAM,CAAC,aAAa,EAAE,eAAe,EAAE,gBAAgB,CAAC,GACtD,MAAM,OAAO,CAAC,GAAG,CAAC;YAChB,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC,GAAG,EAAE;YACpC,IAAI,CAAC,aAAa,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC,GAAG,EAAE;YACtC,IAAI,CAAC,QAAQ;iBACV,GAAG,CACF,SAAS,MAAM,kBAAkB,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,GAAG,CACjF;iBACA,GAAG,EAAE;SACT,CAAC,CAAC;QAEL,IAAI,KAAK,GAAG,CAAC,CAAC;QACd,IAAI,OAAO,GAAG,CAAC,CAAC;QAChB,MAAM,QAAQ,GAAG,gBAAgB,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC,gBAAgB,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;QAExE,IAAI,aAAa,CAAC,MAAM,EAAE,EAAE,CAAC;YAC3B,MAAM,IAAI,GAAG,aAAa,CAAC,GAAG,EAAkB,CAAC;YACjD,IAAI,IAAI,CAAC,IAAI,KAAK,KAAK,EAAE,CAAC;gBACxB,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC;YACrB,CAAC;QACH,CAAC;QAED,IAAI,eAAe,CAAC,MAAM,EAAE,EAAE,CAAC;YAC7B,MAAM,IAAI,GAAG,eAAe,CAAC,GAAG,EAAoB,CAAC;YACrD,IAAI,IAAI,CAAC,KAAK,KAAK,KAAK,EAAE,CAAC;gBACzB,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC;YACvB,CAAC;QACH,CAAC;QAED,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,QAAQ,EAAE,CAAC;IACtC,CAAC;IAED,KAAK,CAAC,UAAU,CAAC,MAAc,EAAE,IAAe;QAC9C,MAAM,KAAK,GAAG,IAAI,CAAC,aAAa,EAAE,CAAC;QACnC,MAAM,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC,GAAG,CAAC,EAAE,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC,CAAC;IACtE,CAAC;IAED,KAAK,CAAC,YAAY,CAAC,MAAc,EAAE,IAAe;QAChD,MAAM,KAAK,GAAG,IAAI,CAAC,cAAc,EAAE,CAAC;QACpC,MAAM,IAAI,CAAC,aAAa,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC,GAAG,CAAC,EAAE,KAAK,EAAE,CAAC,EAAE,KAAK,EAAE,CAAC,CAAC;IAClE,CAAC;CACF;AAtKD,oCAsKC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/lib/utils/index.ts"],"names":[],"mappings":"AAAA,cAAc,YAAY,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/lib/utils/index.ts"],"names":[],"mappings":"AAAA,cAAc,YAAY,CAAC;AAC3B,cAAc,QAAQ,CAAC"}
|
package/dist/lib/utils/index.js
CHANGED
|
@@ -15,4 +15,5 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
|
15
15
|
};
|
|
16
16
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
17
|
__exportStar(require("./sanitize"), exports);
|
|
18
|
+
__exportStar(require("./slug"), exports);
|
|
18
19
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/lib/utils/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,6CAA2B"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/lib/utils/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,6CAA2B;AAC3B,yCAAuB"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { z } from "
|
|
1
|
+
import { z } from "genkit";
|
|
2
2
|
/**
|
|
3
3
|
* Removes HTML tags and script content from a string.
|
|
4
4
|
* Use for text fields that should not contain HTML (descriptions, bios, etc.)
|
|
@@ -11,7 +11,7 @@ export declare function sanitizeText(text: string): string;
|
|
|
11
11
|
* @example
|
|
12
12
|
* const BioSchema = sanitizedString(z.string().max(280));
|
|
13
13
|
*/
|
|
14
|
-
export declare function sanitizedString<T extends z.ZodString>(schema: T): z.
|
|
14
|
+
export declare function sanitizedString<T extends z.ZodString>(schema: T): z.ZodEffects<T, string, z.input<T>>;
|
|
15
15
|
/**
|
|
16
16
|
* Escapes HTML special characters to prevent XSS.
|
|
17
17
|
* Use when HTML needs to be displayed as text.
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"sanitize.d.ts","sourceRoot":"","sources":["../../../src/lib/utils/sanitize.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,
|
|
1
|
+
{"version":3,"file":"sanitize.d.ts","sourceRoot":"","sources":["../../../src/lib/utils/sanitize.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,QAAQ,CAAC;AAE3B;;;GAGG;AACH,wBAAgB,YAAY,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM,CAKjD;AAED;;;;;;GAMG;AACH,wBAAgB,eAAe,CAAC,CAAC,SAAS,CAAC,CAAC,SAAS,EAAE,MAAM,EAAE,CAAC,uCAE/D;AAED;;;GAGG;AACH,wBAAgB,UAAU,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM,CAS/C"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Converts an English name to a URL-safe snake_case slug.
|
|
3
|
+
*
|
|
4
|
+
* @param englishName - The English name to convert
|
|
5
|
+
* @returns A slug matching the format: ^[a-z][a-z0-9_]*[a-z0-9]$
|
|
6
|
+
*
|
|
7
|
+
* @example
|
|
8
|
+
* toSlug("Olive Oil") // "olive_oil"
|
|
9
|
+
* toSlug("Café au lait") // "cafe_au_lait"
|
|
10
|
+
* toSlug("100% Whole Wheat") // "whole_wheat" (numbers at start stripped)
|
|
11
|
+
*/
|
|
12
|
+
export declare function toSlug(englishName: string): string;
|
|
13
|
+
//# sourceMappingURL=slug.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"slug.d.ts","sourceRoot":"","sources":["../../../src/lib/utils/slug.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;GAUG;AACH,wBAAgB,MAAM,CAAC,WAAW,EAAE,MAAM,GAAG,MAAM,CAqBlD"}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.toSlug = toSlug;
|
|
4
|
+
/**
|
|
5
|
+
* Converts an English name to a URL-safe snake_case slug.
|
|
6
|
+
*
|
|
7
|
+
* @param englishName - The English name to convert
|
|
8
|
+
* @returns A slug matching the format: ^[a-z][a-z0-9_]*[a-z0-9]$
|
|
9
|
+
*
|
|
10
|
+
* @example
|
|
11
|
+
* toSlug("Olive Oil") // "olive_oil"
|
|
12
|
+
* toSlug("Café au lait") // "cafe_au_lait"
|
|
13
|
+
* toSlug("100% Whole Wheat") // "whole_wheat" (numbers at start stripped)
|
|
14
|
+
*/
|
|
15
|
+
function toSlug(englishName) {
|
|
16
|
+
let slug = englishName
|
|
17
|
+
.toLowerCase()
|
|
18
|
+
.normalize("NFD")
|
|
19
|
+
.replace(/[\u0300-\u036f]/g, "") // Remove diacritics
|
|
20
|
+
.replace(/[^a-z0-9]+/g, "_") // Replace non-alphanumeric with _
|
|
21
|
+
.replace(/^_+|_+$/g, "") // Trim underscores
|
|
22
|
+
.replace(/_{2,}/g, "_"); // Collapse multiple underscores
|
|
23
|
+
// Ensure starts with letter (strip leading numbers/underscores)
|
|
24
|
+
slug = slug.replace(/^[0-9_]+/, "");
|
|
25
|
+
// Ensure ends with letter or number (strip trailing underscores)
|
|
26
|
+
slug = slug.replace(/_+$/, "");
|
|
27
|
+
// Handle edge case: if slug is too short or empty
|
|
28
|
+
if (slug.length < 2) {
|
|
29
|
+
throw new Error(`Cannot generate valid slug from: "${englishName}"`);
|
|
30
|
+
}
|
|
31
|
+
return slug;
|
|
32
|
+
}
|
|
33
|
+
//# sourceMappingURL=slug.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"slug.js","sourceRoot":"","sources":["../../../src/lib/utils/slug.ts"],"names":[],"mappings":";;AAWA,wBAqBC;AAhCD;;;;;;;;;;GAUG;AACH,SAAgB,MAAM,CAAC,WAAmB;IACxC,IAAI,IAAI,GAAG,WAAW;SACnB,WAAW,EAAE;SACb,SAAS,CAAC,KAAK,CAAC;SAChB,OAAO,CAAC,kBAAkB,EAAE,EAAE,CAAC,CAAC,oBAAoB;SACpD,OAAO,CAAC,aAAa,EAAE,GAAG,CAAC,CAAC,kCAAkC;SAC9D,OAAO,CAAC,UAAU,EAAE,EAAE,CAAC,CAAC,mBAAmB;SAC3C,OAAO,CAAC,QAAQ,EAAE,GAAG,CAAC,CAAC,CAAC,gCAAgC;IAE3D,gEAAgE;IAChE,IAAI,GAAG,IAAI,CAAC,OAAO,CAAC,UAAU,EAAE,EAAE,CAAC,CAAC;IAEpC,iEAAiE;IACjE,IAAI,GAAG,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;IAE/B,kDAAkD;IAClD,IAAI,IAAI,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QACpB,MAAM,IAAI,KAAK,CAAC,qCAAqC,WAAW,GAAG,CAAC,CAAC;IACvE,CAAC;IAED,OAAO,IAAI,CAAC;AACd,CAAC"}
|