- 
                Notifications
    You must be signed in to change notification settings 
- Fork 5.5k
[Web PubSub] Add web pubsub stable version 2021-10-01 #16045
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
Conversation
| Hi, @zackliu Thanks for your PR. I am workflow bot for review process. Here are some small tips.  Any feedback about review process or workflow bot, pls contact swagger and tools team. [email protected] | 
| [Call for Action] To better understand Azure service dev/test scenario, and support Azure service developer better on Swagger and REST API related tests in early phase, please help to fill in with this survey https://aka.ms/SurveyForEarlyPhase. It will take 5 to 10 minutes. If you already complete survey, please neglect this comment. Thanks. | 
| Swagger Validation Report
 | 
| Rule | Message | 
|---|---|
| Consider using x-ms-client-flatten to provide a better end user experience Location: Microsoft.SignalRService/stable/2021-10-01/webpubsub.json#L2306 | |
| Based on the response model schema, operation 'WebPubSub_ListSkus' might be pageable. Consider adding the x-ms-pageable extension. Location: Microsoft.SignalRService/stable/2021-10-01/webpubsub.json#L1238 | 
 The following errors/warnings exist before current PR submission: 
| Rule | Message | 
|---|---|
| The resource 'PrivateLinkResource' does not have get operation, please add it. Location: Microsoft.SignalRService/stable/2021-10-01/webpubsub.json#L1718 | 
️️✔️Avocado succeeded [Detail] [Expand]  
  
Validation passes for Avocado.
️️✔️ModelValidation succeeded [Detail] [Expand]  
  
Validation passes for ModelValidation.
️️✔️SemanticValidation succeeded [Detail] [Expand]  
  
Validation passes for SemanticValidation.
️❌Cross-Version Breaking Changes: 2 Errors, 0 Warnings failed [Detail]   
  
- Compared Swaggers (Based on Oad v0.9.0)- current:stable/2021-10-01/webpubsub.json compared with base:preview/2021-09-01-preview/webpubsub.json
 
| Rule | Message | 
|---|---|
| 1006 - RemovedDefinition | The new version is missing a definition that was found in the old version. Was 'EventHandlerSettings' removed or renamed? New: Microsoft.SignalRService/stable/2021-10-01/webpubsub.json#L1280:3 Old: Microsoft.SignalRService/preview/2021-09-01-preview/webpubsub.json#L1072:3 | 
| 1033 - RemovedProperty | The new version is missing a property found in the old version. Was 'eventHandler' renamed or removed? New: Microsoft.SignalRService/stable/2021-10-01/webpubsub.json#L2415:7 Old: Microsoft.SignalRService/preview/2021-09-01-preview/webpubsub.json#L2125:7 | 
️️✔️CredScan succeeded [Detail] [Expand]  
  
There is no credential detected.
️️✔️[Staging] SDK Track2 Validation succeeded [Detail] [Expand]  
  
Validation passes for SDKTrack2Validation
️️✔️[Staging] PrettierCheck succeeded [Detail] [Expand]  
  
Validation passes for PrettierCheck.
️️✔️[Staging] SpellCheck succeeded [Detail] [Expand]  
  
Validation passes for SpellCheck.
️️✔️[Staging] Lint(RPaaS) succeeded [Detail] [Expand]  
  
Validation passes for Lint(RPaaS).
| Swagger Generation Artifacts
 | 
| Hi, @zackliu your PR are labelled with WaitForARMFeedback. A notification email will be sent out shortly afterwards to notify ARM review board([email protected]). | 
| approve for python breaking change. | 
        
          
                ...resource-manager/Microsoft.SignalRService/stable/2021-10-01/examples/WebPubSubHubs_List.json
              
                Outdated
          
            Show resolved
            Hide resolved
        
              
          
                ...resource-manager/Microsoft.SignalRService/stable/2021-10-01/examples/WebPubSubHubs_List.json
          
            Show resolved
            Hide resolved
        
      | } | ||
| } | ||
| } | ||
| ] | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Nested resource must be created by its own PUT.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The eventHandler in a WebPubSubHub has order. Re-order or replace all the eventhandlers in the webpubsubhub will be easier in such design. I think it's not an implicitly creation. And we'd like to work as keyvault and accesspolicy. KeyVault also show the content of accesspolicy and can update accesspolicy in parent resource's operation. How can we also achieve that?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Then you should model event handlers as a property of webpubsubhub only not as a child resource. You can't have both.
The keyvault case is okay since access policies are a property of keyvault. (its PUT api does not comply to the RPC though).
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
So, if event handler is just a property, can we have an api to update one event handler's properties only. I mean does ARM have such an api guidance to achieve this? Why access policy is just a property but not a sub-resource?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
PATCH is for partial update and it can update one event handler only.
https://github.com/Azure/azure-resource-manager-rpc/blob/master/v1.0/resource-api-reference.md#patch-resource
https://armwiki.azurewebsites.net/api_contracts/guidelines/rpc.html#rpc009-use-put-for-update-of-entire-resource-ie-replace-use-patch-only-for-partial-update-of-resource
You can't model a property of the parent resource as a child resource. They have different RBAC and you need to update the parent if a child resources are updated /deleted or vice versa.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
After discussion, we decided not to introduce another subresource for event handler. We treat it as property only
        
          
                ...manager/Microsoft.SignalRService/stable/2021-10-01/examples/WebPubSubEventHandlers_List.json
              
                Outdated
          
            Show resolved
            Hide resolved
        
              
          
                ...crosoft.SignalRService/stable/2021-10-01/examples/WebPubSubEventHandlers_CreateOrUpdate.json
              
                Outdated
          
            Show resolved
            Hide resolved
        
              
          
                ...ication/webpubsub/resource-manager/Microsoft.SignalRService/stable/2021-10-01/webpubsub.json
              
                Outdated
          
            Show resolved
            Hide resolved
        
              
          
                ...ication/webpubsub/resource-manager/Microsoft.SignalRService/stable/2021-10-01/webpubsub.json
              
                Outdated
          
            Show resolved
            Hide resolved
        
      | @zackliu Next time please follow the instruction for Adding a new API version This allows the reviewer to just compare two commits to see all new changes introduced by the new API version. It will make the review process more efficient. | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Approved from ARM side.
* Add web pubsub stable version 2021-10-01 * Fix structure * Update swagger
* Add web pubsub stable version 2021-10-01 * Fix structure * Update swagger
MSFT employees can try out our new experience at OpenAPI Hub - one location for using our validation tools and finding your workflow.
Changelog
Add a changelog entry for this PR by answering the following questions:
Contribution checklist:
If any further question about AME onboarding or validation tools, please view the FAQ.
ARM API Review Checklist
Otherwise your PR may be subject to ARM review requirements. Complete the following:
Check this box if any of the following apply to the PR so that label “WaitForARMFeedback” will be added automatically to begin ARM API Review. Failure to comply may result in delays to the manifest.
-[ ] To review changes efficiently, ensure you copy the existing version into the new directory structure for first commit and then push new changes, including version updates, in separate commits.
Ensure you've reviewed following guidelines including ARM resource provider contract and REST guidelines. Estimated time (4 hours). This is required before you can request review from ARM API Review board.
If you are blocked on ARM review and want to get the PR merged with urgency, please get the ARM oncall for reviews (RP Manifest Approvers team under Azure Resource Manager service) from IcM and reach out to them.
Breaking Change Review Checklist
If any of the following scenarios apply to the PR, request approval from the Breaking Change Review Board as defined in the Breaking Change Policy.
Action: to initiate an evaluation of the breaking change, create a new intake using the template for breaking changes. Addition details on the process and office hours are on the Breaking change Wiki.
Please follow the link to find more details on PR review process.