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: Implement Client-Side CAB token generation. #1598

Open
wants to merge 1 commit into
base: client-side-cab
Choose a base branch
from

Conversation

huangjiahua
Copy link

@huangjiahua huangjiahua commented Dec 12, 2024

Implement Client-Side CAB token generation.


Thank you for opening a Pull Request! Before submitting your PR, there are a few things you can do to make sure it goes smoothly:

  • Make sure to open an issue as a bug/issue before writing your code! That way we can discuss the change, evaluate designs, and agree on the general idea
  • Ensure the tests and linter pass
  • Code coverage does not decrease (if any source code was changed)
  • Appropriate docs were updated (if necessary)

Fixes #<issue_number_goes_here> ☕️

If you write sample code, please follow the samples format.

@product-auto-label product-auto-label bot added the size: l Pull request size is large. label Dec 12, 2024
@huangjiahua huangjiahua changed the title Generate cab feat: Implement Client-Side CAB token generation. Dec 12, 2024
@huangjiahua huangjiahua marked this pull request as ready for review December 12, 2024 22:10
@huangjiahua huangjiahua requested review from a team as code owners December 12, 2024 22:10
String intermediaryToken, sessionKey;
Date intermediaryTokenExpirationTime;

synchronized (this) {
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Why do we need a synchronized block here?

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Since the value is written in a synchronized block:

synchronized (refreshLock) {
try {
this.intermediateCredentials = Futures.getDone(finishedTask);
} finally {
if (this.refreshTask != null && this.refreshTask.task == finishedTask) {
this.refreshTask = null;
}
}
}
}
.

I'll update my code to use the refreshLock and the IntermediateCredentials wrapper.

@huangjiahua huangjiahua marked this pull request as draft January 8, 2025 23:04
@huangjiahua huangjiahua force-pushed the generate-cab branch 4 times, most recently from 699342c to 2bd4316 Compare January 9, 2025 00:38
Change-Id: I2c217656584cf5805297f02340cbbabca471f609
@huangjiahua huangjiahua marked this pull request as ready for review January 9, 2025 00:59
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
size: l Pull request size is large.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants