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

ClientInitialization/ParamAlias Implementation #5131

Open
Tracked by #1768
lmazuel opened this issue Oct 30, 2024 · 3 comments
Open
Tracked by #1768

ClientInitialization/ParamAlias Implementation #5131

lmazuel opened this issue Oct 30, 2024 · 3 comments
Assignees
Labels

Comments

@lmazuel
Copy link
Member

lmazuel commented Oct 30, 2024

No description provided.

@ArthurMa1978
Copy link
Member

Discussion of this feature is here Azure/typespec-azure#914

@chunyu3 chunyu3 self-assigned this Nov 4, 2024
@chunyu3 chunyu3 added DPG DPG/RLC v2.1 Post Gallium work and removed DPG DPG/RLC v2.1 Post Gallium work labels Nov 4, 2024
@chunyu3
Copy link
Member

chunyu3 commented Nov 5, 2024

We need to discuss if we allow to bump optional parameter to client-level. Azure/typespec-azure#1795

@chunyu3 chunyu3 added DPG DPG/RLC v2.1 Post Gallium work labels Nov 21, 2024
@chunyu3
Copy link
Member

chunyu3 commented Nov 25, 2024

  1. bump required parameter to client-level (AzureSDK generator supported.)
// main.tsp
namespace My.Service;

op upload(@header blobName: string): void;
op download(@header blobName: string): void;

// client.tsp
import "@azure-tools/typespec-client-generator-core";
using Azure.ClientGenerator.Core;

namespace My.Customizations;

model ClientInitOptions {
  blobName: string;
}
@@clientInitialization(MyService, ClientInitOptions)

Generated Code

public class MyServiceClient
{
  private string _blobName;
  
  public Response UploadAsync()
  public Response DownLoadAsync()
}
  1. bump optional parameter to client-leveloptional parameter will be in the clientOptions
// main.tsp
namespace My.Service;

op upload(@header blobName?: string): void;
op download(@header blobName?: string): void;

// client.tsp
import "@azure-tools/typespec-client-generator-core";
using Azure.ClientGenerator.Core;

namespace My.Customizations;

model ClientInitOptions {
  blobName?: string;
}
@@clientInitialization(MyService, ClientInitOptions)

//Generated Code

public class MyServiceClient
{
  private string _blobName;
  
  public Response UploadAsync()
  public Response DownLoadAsync()
}

public class MyServiceClientOptions
{
  public MyServiceClientOptions(ServiceVersion version = LatestVersion, string? blobName=null)
  private string? blobName {get; set}
}
  1. bump a parameter which is an alias (@ParamAlias) of clientinitialModel Property
// main.tsp
namespace My.Service;

op upload(@header blobName: string): void;
op download(@header blobName: string): void;
op theName(@header bName: string): void;

// client.tsp
import "@azure-tools/typespec-client-generator-core";
using Azure.ClientGenerator.Core;

namespace My.Customizations;

model ClientInitOptions {
  blobClientName: string;
}
@@clientInitialization(MyService, ClientInitOptions)
@@paramAlias(ClientInitOptions.blobClientName, "blobName");
@@paramAlias(ClientInitOptions.blobClientName, "bName")

Generated Code

public class MyServiceClient
{
  private string _blobClientName;
  
  public Response UploadAsync()
  public Response DownLoadAsync()
  public Response theName()

  public createUploadRequest()
  {
        ...
        request.Headers.Add("blobName", _blobClientName);
  }
  
  public createDownloadRequest()
  {
        ...
        request.Headers.Add("blobName", _blobClientName);
  }
  
  public createTheNameRequest()
  {
        ...
        request.Headers.Add("bName", _blobClientName);
  }
}

cc @m-nash

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
None yet
Development

No branches or pull requests

3 participants