Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: access bridge service #616

Merged
merged 143 commits into from
Sep 23, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
143 commits
Select commit Hold shift + click to select a range
ef33f18
feat(project): access bridge initial structure
kiremitrov123 Jul 18, 2024
4358d94
feat(project): yarn
kiremitrov123 Jul 18, 2024
88c51b7
feat(project): add lint-staged
kiremitrov123 Jul 18, 2024
e7c582b
feat(project): error for unused imports
kiremitrov123 Jul 19, 2024
3fc50a4
feat(project): remove not needed ls-lint
kiremitrov123 Jul 19, 2024
d6d283b
feat(project): add access tests
kiremitrov123 Jul 20, 2024
d18fe2d
feat(project): rename error message
kiremitrov123 Jul 20, 2024
12cc7f5
feat(project): readme and docs
kiremitrov123 Jul 22, 2024
7399e70
Merge branch 'develop' of https://github.com/jwplayer/ott-web-app int…
kiremitrov123 Jul 22, 2024
ac75a09
chore: rename project in package
kiremitrov123 Jul 22, 2024
5a72ec6
feat(project): include SIMS authorization
kiremitrov123 Jul 22, 2024
aec8347
chore: replace jw/fet with standard prettier config
kiremitrov123 Jul 22, 2024
66e5af9
chore: access-bridge changes to not trigger e2e tests
kiremitrov123 Jul 22, 2024
dada55d
chore: revert web env
kiremitrov123 Jul 22, 2024
478cd3b
feat(project): add stripe products endpoint
kiremitrov123 Jul 23, 2024
7499b37
chore: yarn update
kiremitrov123 Jul 23, 2024
e2e5dc3
feat(project): move types in common package
kiremitrov123 Jul 23, 2024
a88e20b
Merge branch 'IDM-161/IAM-Middleware' of https://github.com/jwplayer/…
kiremitrov123 Jul 23, 2024
c055114
feat(project): update allowed methods
kiremitrov123 Jul 23, 2024
aa8d39a
Merge branch 'IDM-161/IAM-Middleware' of https://github.com/jwplayer/…
kiremitrov123 Jul 23, 2024
c44b17a
chore: rename stripe service fnc name
kiremitrov123 Jul 24, 2024
5f473d5
feat(project): make authorization optional
kiremitrov123 Jul 24, 2024
e1e13aa
Merge branch 'IDM-161/IAM-Middleware' of https://github.com/jwplayer/…
kiremitrov123 Jul 24, 2024
7080e72
feat(project): redefine functions with obj params
kiremitrov123 Jul 24, 2024
81cf353
Merge branch 'IDM-161/IAM-Middleware' of https://github.com/jwplayer/…
kiremitrov123 Jul 24, 2024
5f7c7cf
chore: consistent naming convention
kiremitrov123 Jul 24, 2024
4ad3716
chore: update namings
kiremitrov123 Jul 24, 2024
eabf817
feat(project): add test fixtures
kiremitrov123 Jul 24, 2024
4c2a1cf
Merge branch 'IDM-161/IAM-Middleware' of https://github.com/jwplayer/…
kiremitrov123 Jul 24, 2024
afba6bb
feat(project): add tests for stripe
kiremitrov123 Jul 25, 2024
70b5d9b
feat(project): fine-tune error descriptions
kiremitrov123 Jul 25, 2024
cff8e03
feat(project): use err code enum instead of hardcoded
kiremitrov123 Jul 25, 2024
30cc325
feat(project): add stripe checkout
kiremitrov123 Jul 25, 2024
b5b96e5
chore: move types in common
kiremitrov123 Jul 25, 2024
ed29191
chore: move types in common
kiremitrov123 Jul 25, 2024
36daa91
Merge branch 'IDM-161/IAM-Middleware' of https://github.com/jwplayer/…
kiremitrov123 Jul 25, 2024
2a1ee0e
feat(project): add types in common
kiremitrov123 Jul 25, 2024
54713ec
feat(project): add tests for stripe checkout
kiremitrov123 Jul 26, 2024
e918525
feat(project): add more tests for checkout
kiremitrov123 Jul 28, 2024
0557a39
chore: stripe checkout params
kiremitrov123 Jul 28, 2024
2ba1416
feat(project): add test mocks class
kiremitrov123 Jul 29, 2024
5c2ae2c
feat(project): add metadata in stripe checkout
kiremitrov123 Jul 29, 2024
b5b50c7
feat(project): add viewer from auth token, handle plan external provi…
kiremitrov123 Jul 30, 2024
1284fd6
feat(project): add viewer from auth token, handle plan external provi…
kiremitrov123 Jul 30, 2024
e889ebd
feat(project): update stripe products filter
kiremitrov123 Jul 30, 2024
c4231be
feat(project): use external providers
kiremitrov123 Jul 30, 2024
ce3d54e
chore: update readme
kiremitrov123 Jul 31, 2024
d146dba
Merge branch 'develop' of https://github.com/jwplayer/ott-web-app int…
kiremitrov123 Jul 31, 2024
bcd00ed
Merge branch 'IDM-161/IAM-Middleware' of https://github.com/jwplayer/…
kiremitrov123 Jul 31, 2024
6b1dba3
feat(project): update docs
kiremitrov123 Jul 31, 2024
6724a9f
Merge branch 'IDM-169/stripe-products' of https://github.com/jwplayer…
kiremitrov123 Jul 31, 2024
f84494e
feat(project): add account service
kiremitrov123 Jul 31, 2024
93b7698
Merge branch 'IDM-161/IAM-Middleware' of https://github.com/jwplayer/…
kiremitrov123 Jul 31, 2024
7489d07
feat(project): add accounts service usage
kiremitrov123 Jul 31, 2024
9955d55
chore: remove unused util fnc
kiremitrov123 Jul 31, 2024
2cb2c96
Merge branch 'IDM-161/IAM-Middleware' of https://github.com/jwplayer/…
kiremitrov123 Jul 31, 2024
75a4989
Merge branch 'IDM-169/stripe-products' of https://github.com/jwplayer…
kiremitrov123 Jul 31, 2024
e175c3b
feat(project): add sentry
kiremitrov123 Aug 1, 2024
0ac404a
feat(project): replace node with vite
kiremitrov123 Aug 20, 2024
3c38ca0
feat(project): refactor server to use express, refactor error handlin…
kiremitrov123 Aug 21, 2024
c7b5718
feat(project): add types for express
kiremitrov123 Aug 21, 2024
c88e831
chore: add .test in the test naimings
kiremitrov123 Aug 21, 2024
0a02f3e
fix: vite version mismatch
kiremitrov123 Aug 21, 2024
5fdfd3c
feat(project): update docs
kiremitrov123 Aug 22, 2024
61e01ea
Merge branch 'develop' of https://github.com/jwplayer/ott-web-app int…
kiremitrov123 Aug 22, 2024
b164ad4
chore: add dummy env variables in the test-unit-snapshot workflow
kiremitrov123 Aug 22, 2024
d7715ce
feat(project): address changes of vite, express and vitest
kiremitrov123 Aug 22, 2024
e9cd076
feat(project): refactor services, decouple plans method
kiremitrov123 Aug 22, 2024
67d8b42
feat(project): update products controller and tests to match the refa…
kiremitrov123 Aug 22, 2024
73d7945
feat(project): refactor app to use vite, express and vitest for testing
kiremitrov123 Aug 22, 2024
24ef0fe
feat(project): load sentry after build
kiremitrov123 Aug 25, 2024
5e13a20
feat(project): add sentry source mapping
kiremitrov123 Aug 25, 2024
08f994b
feat(project): add sentry version and environment
kiremitrov123 Aug 26, 2024
ed41bf4
chore: remove debug sentry
kiremitrov123 Aug 26, 2024
0bb0bd6
feat(project): additional test build for not source mapping on test
kiremitrov123 Aug 26, 2024
239742e
feat(project): add stripe billing portal endpoint
kiremitrov123 Aug 26, 2024
889d299
chore: update readme
kiremitrov123 Aug 26, 2024
c73487f
chore: add stripe dummy secret on test-unit workflow
kiremitrov123 Aug 26, 2024
264a1f6
Merge branch 'IDM-169/stripe-products' of https://github.com/jwplayer…
kiremitrov123 Aug 26, 2024
2797ec3
chore: update checkout params
kiremitrov123 Aug 26, 2024
7fb5808
Merge branch 'IDM-209/stripe-checkout' of https://github.com/jwplayer…
kiremitrov123 Aug 26, 2024
a4e7209
Merge branch 'IDM-220/error-logging' of https://github.com/jwplayer/o…
kiremitrov123 Aug 26, 2024
987e5fa
feat(project): add cors middleware
kiremitrov123 Aug 26, 2024
132e8a2
Merge branch 'IDM-161/IAM-Middleware' of https://github.com/jwplayer/…
kiremitrov123 Aug 26, 2024
6120337
feat(project): add cors middleware
kiremitrov123 Aug 26, 2024
27f115b
feat(project): add site_id in the route
kiremitrov123 Aug 26, 2024
e022515
Merge branch 'IDM-209/stripe-checkout' of https://github.com/jwplayer…
kiremitrov123 Aug 26, 2024
8204e15
feat(project): add site_id in the route
kiremitrov123 Aug 26, 2024
8ef6a24
feat(project): update port it can match google cloud run reqs
kiremitrov123 Aug 29, 2024
8ed3c59
feat(project): use newer version of node to make happy sentry
kiremitrov123 Aug 29, 2024
2a4da7b
feat(project): move error handling to the middleware
kiremitrov123 Sep 3, 2024
7dabd37
feat(project): add refresh passport
kiremitrov123 Sep 3, 2024
07bb8df
chore: update branch
kiremitrov123 Sep 3, 2024
6551e2d
chore: update branch
kiremitrov123 Sep 3, 2024
5ea2d83
feat(project): remove error handling from services
kiremitrov123 Sep 3, 2024
115a218
feat(project): simplify jw error usage
kiremitrov123 Sep 3, 2024
3bd7d10
feat(project): handle stripe errros simplified
kiremitrov123 Sep 3, 2024
f36f1ca
feat(project): remove service level error handling
kiremitrov123 Sep 3, 2024
29fa3f3
feat(project): move error handling to the middleware
kiremitrov123 Sep 3, 2024
3c2bddc
feat(project): remove error handling from service level
kiremitrov123 Sep 3, 2024
54a5477
feat(project): refactor routes and middlewares
kiremitrov123 Sep 11, 2024
d7eacd2
feat(project): refactor structure and namings
kiremitrov123 Sep 11, 2024
7699732
feat(project): add missing case for refresh passport test
kiremitrov123 Sep 11, 2024
69b32de
feat(project): load envs at runtime
kiremitrov123 Sep 12, 2024
514e999
fix(search): override search query cache (#594)
langemike Sep 4, 2024
9d78554
feat(project): app metadata insertion
royschut Sep 4, 2024
a0a7fc4
feat(project): add injectable wrapper to common components (#598)
royschut Sep 4, 2024
2a0e3ca
refactor(project): update services members visibility and explicit in…
ChristiaanScheermeijer Sep 4, 2024
0c3a6ba
feat(project): remove free and productIds from content-types.json (#605)
CarinaDraganJW Sep 5, 2024
5e59035
fix(e2e): fix tests after cleeng api update (#606)
AntonLantukh Sep 6, 2024
cb0df4f
chore(release): v6.6.0
invalid-email-address Sep 6, 2024
0039674
feat(project): refactor routes and middlewares
kiremitrov123 Sep 11, 2024
def9b1c
feat(project): rebase and stuff
kiremitrov123 Sep 12, 2024
72a186a
Merge branch 'develop' of https://github.com/jwplayer/ott-web-app int…
kiremitrov123 Sep 12, 2024
8cb18a7
feat(project): simplify using routes and middlewares
kiremitrov123 Sep 12, 2024
a2e6541
feat(project): add generic payment service that other services will i…
kiremitrov123 Sep 12, 2024
1979ae0
feat(project): update products to use our own types
kiremitrov123 Sep 13, 2024
2272643
chore: add site_id in .env.example
kiremitrov123 Sep 13, 2024
b267b61
feat(project): add stripe error handler in middleware
kiremitrov123 Sep 13, 2024
cd9adc2
feat(project): simplify checkout controller to use shared service iml…
kiremitrov123 Sep 13, 2024
dfa24f0
chore: update readme
kiremitrov123 Sep 13, 2024
29199eb
chore: update comments on stripe payment service
kiremitrov123 Sep 13, 2024
a57359b
chore: remove unused type
kiremitrov123 Sep 13, 2024
5ce22c1
feat(project): adapt new structure and move logger
kiremitrov123 Sep 13, 2024
584cb59
feat(project): update sentry and logger
kiremitrov123 Sep 13, 2024
6173558
chore: node-version
kiremitrov123 Sep 13, 2024
c4b2751
chore: revert node version
kiremitrov123 Sep 13, 2024
53ab754
feat(project): update billing portal url to use the new structure
kiremitrov123 Sep 13, 2024
1f4f826
chore: update comment on checkout controller
kiremitrov123 Sep 13, 2024
cfd5826
chore: revert node version
kiremitrov123 Sep 13, 2024
fb10424
chore: revert env to default
kiremitrov123 Sep 16, 2024
93f78d4
feat(project): modify types for products and prices
kiremitrov123 Sep 16, 2024
3c4220f
feat(project): update test fixtures
kiremitrov123 Sep 16, 2024
f8822f6
Merge branch 'IDM-209/stripe-checkout' of https://github.com/jwplayer…
kiremitrov123 Sep 16, 2024
0504c5b
feat(project): update typings and product fixtures
kiremitrov123 Sep 16, 2024
5968134
feat(project): add deployment file and docs
kiremitrov123 Sep 17, 2024
d5cff56
chore: update readme paths
kiremitrov123 Sep 17, 2024
6aad880
feat(project): remove mode from checkout params
kiremitrov123 Sep 19, 2024
e9cde38
feat(project): remove stripe type
kiremitrov123 Sep 19, 2024
3c81aca
feat(project): merge with develop
kiremitrov123 Sep 19, 2024
83332e7
chore: remove vite build file
kiremitrov123 Sep 19, 2024
df86b96
Merge branch 'develop' of https://github.com/jwplayer/ott-web-app int…
kiremitrov123 Sep 19, 2024
4202042
Merge branch 'develop' into feat/access-bridge-service
kiremitrov123 Sep 19, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
10 changes: 9 additions & 1 deletion .github/workflows/test-unit-snapshot.yml
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
name: Test - Unit and Snapshot
name: Test - Unit, Integration, Snapshot

on:
push:
Expand All @@ -21,3 +21,11 @@ jobs:
yarn test
env:
CI: true
# Dummy environment variables for testing the access-bridge service
APP_SITE_ID: test1234
APP_API_SECRET: dummy_secret
APP_STRIPE_SECRET: dummy_stripe_secret
APP_BIND_ADDR: localhost
APP_BIND_PORT: 8080
APP_ACCESS_CONTROL_API_HOST: https://test-cdn.jwplayer.com
APP_SIMS_API_HOST: https://test-sims.jwplayer.com
1 change: 0 additions & 1 deletion knip.config.ts
Original file line number Diff line number Diff line change
Expand Up @@ -38,7 +38,6 @@ const config: KnipConfig = {
'i18next-parser',
'luxon', // Used in tests
'playwright', // Used in test configs
'sharp', // Requirement for @vite-pwa/assets-generator
'tsconfig-paths', // Used for e2e test setup
'virtual:pwa-register', // Service Worker code is injected at build time
'virtual:polyfills', // Polyfills are conditionally injected
Expand Down
3 changes: 2 additions & 1 deletion package.json
Original file line number Diff line number Diff line change
Expand Up @@ -33,7 +33,8 @@
"prepare": "husky install",
"test": "TZ=UTC LC_ALL=en_US.UTF-8 vitest run",
"test-watch": "TZ=UTC LC_ALL=en_US.UTF-8 vitest",
"web": "yarn --cwd platforms/web"
"web": "yarn --cwd platforms/web",
"access-bridge": "yarn --cwd platforms/access-bridge"
},
"devDependencies": {
"@commitlint/cli": "^17.8.1",
Expand Down
8 changes: 8 additions & 0 deletions packages/common/types/errors.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
export type JWError = {
code: string;
description: string;
};

export type JWErrorResponse = {
errors: JWError[];
};
4 changes: 4 additions & 0 deletions packages/common/types/passport.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
export type PassportResponse = {
passport: string;
refresh_token: string;
};
49 changes: 49 additions & 0 deletions packages/common/types/payment.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,49 @@
type Recurrence = {
// The frequency at which a subscription is billed. One of `day`, `week`, `month`, or `year`.
interval: 'day' | 'week' | 'month' | 'year';
// Recurrence duration, for example, `interval=month` and `duration=3` bills every 3 months.
duration: number;
// Trial period interval. For example, a month-long trial is different from a 30-day trial.
trial_period_interval: 'day' | 'week' | 'month' | 'year';
// Duration of the trial period (in the unit defined by trial_period_interval).
trial_period_duration: number | null;
};

export type Price = {
// Unique identifier for the object.
store_price_id: string;
// Dictionary of currencies, where the key is the currency code and the value is an object with an amount property.
// Three-letter [ISO currency code](https://www.iso.org/iso-4217-currency-codes.html), in lowercase.
currencies: {
[currency_code: string]: {
// The unit amount in cents (or local equivalent) to be charged, represented as a whole integer.
amount: number | null;
};
};
// Default currency code for this price.
default_currency: string;
// Recurrence details. Can be a Recurrence object or 'one_time'.
recurrence: Recurrence | 'one_time';
// Billing scheme. For now, we only support `per_unit`.
billing_scheme: 'per_unit';
};

export type Product = {
// Unique identifier for the object.
store_product_id: string;
// The product's name, meant to be displayable to the customer.
name: string;
// The product's description, meant to be displayable to the customer.
description: string;
// The ID of the default price this product is associated with.
default_store_price_id: string;
// Array of price objects.
prices: Price[];
};

// General checkout parameters type. Can be extended by specific payment providers, e.g. Stripe
export type CheckoutParams = {
price_id: string;
success_url: string;
cancel_url: string;
};
31 changes: 31 additions & 0 deletions packages/common/types/plans.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,31 @@
type AccessOptions = {
drm_policy_id: string;
};

type PlanExternalProviders = {
stripe?: string;
apple?: string;
google?: string;
};

export type AccessControlPlan = {
id: string;
exp: number;
};

export type Plan = {
id: string;
exp: number;
access_model: 'free' | 'freeauth' | 'svod';
access: AccessOptions;
metadata: {
external_providers: PlanExternalProviders;
};
};

export type PlansResponse = {
total: number;
page: number;
page_length: number;
plans: Plan[];
};
37 changes: 37 additions & 0 deletions platforms/access-bridge/.env.example
Original file line number Diff line number Diff line change
@@ -0,0 +1,37 @@
# Application version - Used for tracking and identifying specific releases.
# Automatically set to the version specified in package.json.
# Helps in associating logs, errors, and other metrics with particular versions of the application.
APP_VERSION=$npm_package_version

# Secrets responsible for signing a request to authenticate with the JW Delivery Gateway.
# In order to use the AC System this authentication is crucial.
# The secrets can be found in the JW Dashboard, under the API Credentials in the top right settings icon.
# Make sure the secrets are V1 and that they refer to the desired property.
# For production env, use this reference on how to store them: https://cloud.google.com/run/docs/configuring/services/secrets
APP_API_SECRET=customer_v1_secret
# site_id or property_id represents the key that corresponds to the APP_API_SECRET defined earlier.
APP_SITE_ID=customer_site_id
# Stripe secret responsible for authenticating Stripe API calls
APP_STRIPE_SECRET=stripe_secret

# Non-secret variables
# Specifies the network address or IP address on which the server listens for incoming connections.
APP_BIND_ADDR=localhost
# Specifies the port number on which the server listens for incoming connections.
APP_BIND_PORT=8080
# Specifies the client URL responsible for access related stuff
APP_ACCESS_CONTROL_API_HOST=https://cdn-dev.jwplayer.com
# Specifies the client URL responsible for plans related stuff
APP_SIMS_API_HOST=https://daily-sims.jwplayer.com

# These are optional and should be added only if tracing with Sentry is needed
# Set the APP_SENTRY_DSN variable to enable Sentry error tracking and performance monitoring.
# Set APP_SENTRY_AUTH_TOKEN to allow Sentry to provide readable stack traces (source maps).
# If this variable is not set, Sentry will not be initialized.
# For production environments, ensure you configure the `APP_SENTRY_TRACE_RATE`
# according to your monitoring needs to balance performance and resource usage.
APP_SENTRY_DSN=
APP_SENTRY_AUTH_TOKEN=
APP_SENTRY_TRACE_RATE=
APP_SENTRY_ORG_NAME=
APP_SENTRY_PROJ_NAME=
12 changes: 12 additions & 0 deletions platforms/access-bridge/.eslintrc.cjs
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
module.exports = {
extends: ['jwp/typescript'],
rules: {
"max-len": ["error", { "code": 120 }],
"import/no-unused-modules": ["error"]
},
env: {
node: true, // Enables recognition of Node.js global variables and scoping rules
},
ignorePatterns: ['build'],
};

6 changes: 6 additions & 0 deletions platforms/access-bridge/.gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
node_modules
build
*.local
.env
# Sentry Config File
.env.sentry-build-plugin
1 change: 1 addition & 0 deletions platforms/access-bridge/.prettierignore
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
build
70 changes: 70 additions & 0 deletions platforms/access-bridge/Makefile
Original file line number Diff line number Diff line change
@@ -0,0 +1,70 @@
PACKAGE_JSON := ./package.json
BACKUP_PACKAGE_JSON := ./package-backup.json
ROOT_YARN_LOCK := ../../yarn.lock
PROJECT_YARN_LOCK := ./yarn.lock

# Default target: deploy and ensure cleanup runs regardless
.PHONY: deploy
deploy: check-setup backup-package modify-package copy-yarn-lock try-deploy post-deploy

# Step 0: Check setup
.PHONY: check-setup
check-setup:
@echo "Checking setup..."
@command -v gcloud >/dev/null 2>&1 || { echo "Error: gcloud is not installed. Please install Google Cloud SDK."; exit 1; }
@command -v yarn >/dev/null 2>&1 || { echo "Error: yarn is not installed. Please install Yarn."; exit 1; }
@echo "All required tools are installed."
@# Check if Google Cloud is configured
@gcloud config get-value project >/dev/null 2>&1 || { echo "Error: Google Cloud project is not configured. Run 'gcloud init'."; exit 1; }
@echo "Google Cloud is configured."

# Step 1: Backup the original package.json
.PHONY: backup-package
backup-package:
@echo "Deployment started..."
@cp $(PACKAGE_JSON) $(BACKUP_PACKAGE_JSON)

# Step 2: Modify `package.json` by removing internal dependencies
# In a monorepo setup, internal packages are not deployed. This step ensures that only the relevant,
# external dependencies are included in the `package.json` for deployment.
.PHONY: modify-package
modify-package:
@# Use `sed` to remove specific internal dependencies by editing package.json in place
@sed -i.bak '/"@jwp\/ott-common"/d' $(PACKAGE_JSON)
@sed -i.bak '/"eslint-config-jwp"/d' $(PACKAGE_JSON)
@rm -f $(PACKAGE_JSON).bak

# Step 3: Copy the root `yarn.lock` to the project directory
# To maintain dependency consistency in a monorepo, copy the root `yarn.lock` file to the project
# directory so Google Cloud Run can correctly compare and resolve dependencies.
.PHONY: copy-yarn-lock
copy-yarn-lock:
@cp $(ROOT_YARN_LOCK) $(PROJECT_YARN_LOCK)

# Step 4: Deploy to Google Cloud Run
.PHONY: try-deploy
try-deploy:
@{ \
set -e; \
trap 'make post-deploy; exit 1;' INT TERM HUP; \
gcloud run deploy access-bridge \
--source=. \
--platform=managed \
--region= \
--allow-unauthenticated; \
make post-deploy; \
}

# Step 5: Cleanup (run whether deploy succeeds or fails)
.PHONY: post-deploy
post-deploy: restore-package clean

# Step 6: Restore the original package.json
.PHONY: restore-package
restore-package:
@mv $(BACKUP_PACKAGE_JSON) $(PACKAGE_JSON)

# Step 7: Clean up copied yarn.lock
.PHONY: clean
clean:
@rm -f $(PROJECT_YARN_LOCK)
134 changes: 134 additions & 0 deletions platforms/access-bridge/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,134 @@
# Access Bridge

A service that facilitates seamless communication between the Subscriber Identity Management System (SIMS) and Access Control services. It provides endpoints to generate access passports for authenticated viewers, ensuring secure and efficient access management.

## Local Setup for Environment Variables

To set up the project locally, you need to configure environment variables that are crucial for authenticating with the JW Delivery Gateway and for specifying server configurations.

Here’s how you can set them up:

Create a `.env.local` file in the root of this project and add the following variables:

- APP_API_SITE_ID=customer_site_id
- APP_API_SECRET=customer_v1_secret
- APP_BIND_ADDR=localhost
- APP_BIND_PORT=8080
- APP_ACCESS_CONTROL_API_HOST=https://cdn-dev.jwplayer.com
<em>(Use https://cdn.jwplayer.com for production)</em>
- APP_SIMS_API_HOST=https://daily-sims.jwplayer.com
<em>(Use https://sims.jwplayer.com for production)</em>

Make sure to replace the placeholder values (e.g., customer_v1_secret) with the actual values from your JW Dashboard.
You can also copy and paste the contents of `.env.example` into `.env.local` and just adjust the APP_API_SECRET.

## Getting started

- Run `yarn` to install dependencies
- Navigate to the platform directory `cd platforms/access-bridge`
- Run tests through `yarn test`
- Run `yarn start` to start the server

## Exposed endpoints

#### URL: `/v2/sites/{site_id}/access/generate`

- **Method:** PUT
- **Authorization:** Valid SIMS token
- **Summary:** Generates a new passport for an authenticated viewer based on the information inside the SIMS token.
- **Response:**
```json
{
"passport": "encrypted_passport",
"refresh_token": "random_string"
}
```

#### URL: `/v2/sites/{site_id}/access/refresh`

- **Method:** PUT
- **Authorization:** Valid SIMS token
- **Summary:** Regenerates an existing passport with a new expiry and a new refresh token.
- **Request:**
```json
{
"refresh_token": "string"
}
```
- **Response:**
```json
{
"passport": "encrypted_passport",
"refresh_token": "random_string"
}
```

#### URL: `/v2/sites/{site_id}/products`

- **Method:** GET
- **Authorization:** None
- **Summary:** Lists all the corresponding stripe products with prices that are connected to the SIMS plans.
- **Response:** [Product payment type](../../../ott-web-app/packages/common/types/payment.ts)
```json
[
{
// ...
"id": "prod_QRUHbH7wK5HHPr",
"default_price": "price_1PabInA9TD3ZjIM6EEnKSR7U",
// ...
"prices": [
{
// ...
"id": "price_1PabInA9TD3ZjIM6EEnKSR7U",
"currency": "usd",
"unit_amount": 15000
// ...
}
]
}
// ...
]
```

#### URL: `/v2/sites/{site_id}/checkout`

- **Method:** POST
- **Authorization:** Valid SIMS token
- **Summary:** Creates Payment Checkout Session URL where the viewer will be redirected to complete the payment.
- **Request:**
```json
{
"price_id": "string", // id of the price that is about to be paid
"mode": "string", // subscription (recurring) | payment (one time purchases)
"success_url": "string", // redirect after successful payment
"cancel_url": "string" // redirect after cancel / invalid payment
}
```
- **Response:**
```json
{
"url": "string" // url where the viewer will be redirected to complete the payment.
}
```

#### URL: `/v2/sites/{site_id}/billing-portal`

- **Method:** POST
- **Authorization:** Valid SIMS token
- **Summary:** Generates Billing Portal Url, where the viewer can view / update their purchase info.
- **Response:**
```json
{
"url": "billing-portal-url"
}
```

## Developer guidelines

- Read the workspace guidelines here [developer-guidelines.md](./docs/developer-guidelines.md).
- Read the deployment guidelines here [deployment.md](./docs/deployment.md).
- Read the web platform guidelines here [developer-guidelines.md](../../docs/developer-guidelines.md).

```

```
Loading
Loading