@openrouter/sdk 0.0.0-beta.38 → 0.0.0-beta.39
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/commonjs/funcs/betaResponsesSend.js +1 -1
- package/dist/commonjs/funcs/betaResponsesSend.js.map +1 -1
- package/dist/commonjs/funcs/chatSend.js +1 -1
- package/dist/commonjs/funcs/chatSend.js.map +1 -1
- package/dist/commonjs/funcs/custom/oAuthCreateAuthorizationUrl.d.ts +43 -0
- package/dist/commonjs/funcs/custom/oAuthCreateAuthorizationUrl.d.ts.map +1 -0
- package/dist/commonjs/funcs/custom/oAuthCreateAuthorizationUrl.js +50 -0
- package/dist/commonjs/funcs/custom/oAuthCreateAuthorizationUrl.js.map +1 -0
- package/dist/commonjs/funcs/custom/oAuthCreateAuthorizationUrl.test.d.ts +2 -0
- package/dist/commonjs/funcs/custom/oAuthCreateAuthorizationUrl.test.d.ts.map +1 -0
- package/dist/commonjs/funcs/custom/oAuthCreateAuthorizationUrl.test.js +213 -0
- package/dist/commonjs/funcs/custom/oAuthCreateAuthorizationUrl.test.js.map +1 -0
- package/dist/commonjs/funcs/custom/oAuthCreateSHA256CodeChallenge.d.ts +35 -0
- package/dist/commonjs/funcs/custom/oAuthCreateSHA256CodeChallenge.d.ts.map +1 -0
- package/dist/commonjs/funcs/custom/oAuthCreateSHA256CodeChallenge.js +75 -0
- package/dist/commonjs/funcs/custom/oAuthCreateSHA256CodeChallenge.js.map +1 -0
- package/dist/commonjs/funcs/custom/oAuthCreateSHA256CodeChallenge.test.d.ts +2 -0
- package/dist/commonjs/funcs/custom/oAuthCreateSHA256CodeChallenge.test.d.ts.map +1 -0
- package/dist/commonjs/funcs/custom/oAuthCreateSHA256CodeChallenge.test.js +164 -0
- package/dist/commonjs/funcs/custom/oAuthCreateSHA256CodeChallenge.test.js.map +1 -0
- package/dist/commonjs/funcs/modelsList.js +1 -1
- package/dist/commonjs/funcs/modelsList.js.map +1 -1
- package/dist/commonjs/lib/config.d.ts +3 -3
- package/dist/commonjs/lib/config.js +3 -3
- package/dist/commonjs/lib/config.js.map +1 -1
- package/dist/commonjs/models/chatgenerationparams.d.ts +16 -42
- package/dist/commonjs/models/chatgenerationparams.d.ts.map +1 -1
- package/dist/commonjs/models/chatgenerationparams.js +27 -6
- package/dist/commonjs/models/chatgenerationparams.js.map +1 -1
- package/dist/commonjs/models/chatmessagecontentitemaudio.d.ts +6 -22
- package/dist/commonjs/models/chatmessagecontentitemaudio.d.ts.map +1 -1
- package/dist/commonjs/models/chatmessagecontentitemaudio.js +10 -2
- package/dist/commonjs/models/chatmessagecontentitemaudio.js.map +1 -1
- package/dist/commonjs/models/chatmessagecontentitemimage.d.ts +6 -14
- package/dist/commonjs/models/chatmessagecontentitemimage.d.ts.map +1 -1
- package/dist/commonjs/models/chatmessagecontentitemimage.js +10 -2
- package/dist/commonjs/models/chatmessagecontentitemimage.js.map +1 -1
- package/dist/commonjs/models/chatresponsechoice.d.ts +6 -18
- package/dist/commonjs/models/chatresponsechoice.d.ts.map +1 -1
- package/dist/commonjs/models/chatresponsechoice.js +10 -2
- package/dist/commonjs/models/chatresponsechoice.js.map +1 -1
- package/dist/commonjs/models/chatstreamingchoice.d.ts +6 -18
- package/dist/commonjs/models/chatstreamingchoice.d.ts.map +1 -1
- package/dist/commonjs/models/chatstreamingchoice.js +10 -2
- package/dist/commonjs/models/chatstreamingchoice.js.map +1 -1
- package/dist/commonjs/models/completionfinishreason.d.ts +6 -14
- package/dist/commonjs/models/completionfinishreason.d.ts.map +1 -1
- package/dist/commonjs/models/completionfinishreason.js +10 -2
- package/dist/commonjs/models/completionfinishreason.js.map +1 -1
- package/dist/commonjs/models/endpointslist.d.ts +21 -269
- package/dist/commonjs/models/endpointslist.d.ts.map +1 -1
- package/dist/commonjs/models/endpointslist.js +37 -8
- package/dist/commonjs/models/endpointslist.js.map +1 -1
- package/dist/commonjs/models/errorresponse.d.ts +6 -148
- package/dist/commonjs/models/errorresponse.d.ts.map +1 -1
- package/dist/commonjs/models/errorresponse.js +10 -2
- package/dist/commonjs/models/errorresponse.js.map +1 -1
- package/dist/commonjs/models/modelslist.d.ts +26 -178
- package/dist/commonjs/models/modelslist.d.ts.map +1 -1
- package/dist/commonjs/models/modelslist.js +46 -11
- package/dist/commonjs/models/modelslist.js.map +1 -1
- package/dist/commonjs/models/operations/addcoinbasecharge.d.ts +6 -14
- package/dist/commonjs/models/operations/addcoinbasecharge.d.ts.map +1 -1
- package/dist/commonjs/models/operations/addcoinbasecharge.js +9 -2
- package/dist/commonjs/models/operations/addcoinbasecharge.js.map +1 -1
- package/dist/commonjs/models/operations/create.d.ts +6 -14
- package/dist/commonjs/models/operations/create.d.ts.map +1 -1
- package/dist/commonjs/models/operations/create.js +10 -2
- package/dist/commonjs/models/operations/create.js.map +1 -1
- package/dist/commonjs/models/operations/createauthorizationcode.d.ts +6 -12
- package/dist/commonjs/models/operations/createauthorizationcode.d.ts.map +1 -1
- package/dist/commonjs/models/operations/createauthorizationcode.js +9 -2
- package/dist/commonjs/models/operations/createauthorizationcode.js.map +1 -1
- package/dist/commonjs/models/operations/exchangeauthorizationcode.d.ts +6 -12
- package/dist/commonjs/models/operations/exchangeauthorizationcode.d.ts.map +1 -1
- package/dist/commonjs/models/operations/exchangeauthorizationcode.js +9 -2
- package/dist/commonjs/models/operations/exchangeauthorizationcode.js.map +1 -1
- package/dist/commonjs/models/operations/generate.d.ts +37 -569
- package/dist/commonjs/models/operations/generate.d.ts.map +1 -1
- package/dist/commonjs/models/operations/generate.js +55 -12
- package/dist/commonjs/models/operations/generate.js.map +1 -1
- package/dist/commonjs/models/operations/getmetadata.d.ts +6 -12
- package/dist/commonjs/models/operations/getmetadata.d.ts.map +1 -1
- package/dist/commonjs/models/operations/getmetadata.js +9 -2
- package/dist/commonjs/models/operations/getmetadata.js.map +1 -1
- package/dist/commonjs/models/operations/getparameters.d.ts +11 -189
- package/dist/commonjs/models/operations/getparameters.d.ts.map +1 -1
- package/dist/commonjs/models/operations/getparameters.js +19 -4
- package/dist/commonjs/models/operations/getparameters.js.map +1 -1
- package/dist/commonjs/models/operations/list.d.ts +21 -125
- package/dist/commonjs/models/operations/list.d.ts.map +1 -1
- package/dist/commonjs/models/operations/list.js +36 -8
- package/dist/commonjs/models/operations/list.js.map +1 -1
- package/dist/commonjs/models/operations/previewzdr.d.ts +21 -269
- package/dist/commonjs/models/operations/previewzdr.d.ts.map +1 -1
- package/dist/commonjs/models/operations/previewzdr.js +38 -9
- package/dist/commonjs/models/operations/previewzdr.js.map +1 -1
- package/dist/commonjs/models/operations/sendresponsesrequest.d.ts +57 -621
- package/dist/commonjs/models/operations/sendresponsesrequest.d.ts.map +1 -1
- package/dist/commonjs/models/operations/sendresponsesrequest.js +88 -20
- package/dist/commonjs/models/operations/sendresponsesrequest.js.map +1 -1
- package/dist/commonjs/models/operations/update.d.ts +6 -14
- package/dist/commonjs/models/operations/update.d.ts.map +1 -1
- package/dist/commonjs/models/operations/update.js +10 -2
- package/dist/commonjs/models/operations/update.js.map +1 -1
- package/dist/commonjs/models/responsefunctioncallstatus.d.ts +6 -14
- package/dist/commonjs/models/responsefunctioncallstatus.d.ts.map +1 -1
- package/dist/commonjs/models/responsefunctioncallstatus.js +10 -2
- package/dist/commonjs/models/responsefunctioncallstatus.js.map +1 -1
- package/dist/commonjs/models/responseimagegenerationcallstatus.d.ts +6 -16
- package/dist/commonjs/models/responseimagegenerationcallstatus.d.ts.map +1 -1
- package/dist/commonjs/models/responseimagegenerationcallstatus.js +10 -2
- package/dist/commonjs/models/responseimagegenerationcallstatus.js.map +1 -1
- package/dist/commonjs/models/responseincludable.d.ts +6 -18
- package/dist/commonjs/models/responseincludable.d.ts.map +1 -1
- package/dist/commonjs/models/responseincludable.js +10 -2
- package/dist/commonjs/models/responseincludable.js.map +1 -1
- package/dist/commonjs/models/responseinputimagedetail.d.ts +6 -14
- package/dist/commonjs/models/responseinputimagedetail.d.ts.map +1 -1
- package/dist/commonjs/models/responseinputimagedetail.js +10 -2
- package/dist/commonjs/models/responseinputimagedetail.js.map +1 -1
- package/dist/commonjs/models/responsereasoningconfig.d.ts +6 -16
- package/dist/commonjs/models/responsereasoningconfig.d.ts.map +1 -1
- package/dist/commonjs/models/responsereasoningconfig.js +10 -2
- package/dist/commonjs/models/responsereasoningconfig.js.map +1 -1
- package/dist/commonjs/models/responsereasoningsummarymode.d.ts +6 -14
- package/dist/commonjs/models/responsereasoningsummarymode.d.ts.map +1 -1
- package/dist/commonjs/models/responsereasoningsummarymode.js +10 -2
- package/dist/commonjs/models/responsereasoningsummarymode.js.map +1 -1
- package/dist/commonjs/models/responsesincompletedetails.d.ts +6 -12
- package/dist/commonjs/models/responsesincompletedetails.d.ts.map +1 -1
- package/dist/commonjs/models/responsesincompletedetails.js +10 -2
- package/dist/commonjs/models/responsesincompletedetails.js.map +1 -1
- package/dist/commonjs/models/responsesnonstreamingresponse.d.ts +21 -61
- package/dist/commonjs/models/responsesnonstreamingresponse.d.ts.map +1 -1
- package/dist/commonjs/models/responsesnonstreamingresponse.js +35 -8
- package/dist/commonjs/models/responsesnonstreamingresponse.js.map +1 -1
- package/dist/commonjs/models/responsesoutputitemfilesearchcall.d.ts +6 -16
- package/dist/commonjs/models/responsesoutputitemfilesearchcall.d.ts.map +1 -1
- package/dist/commonjs/models/responsesoutputitemfilesearchcall.js +9 -2
- package/dist/commonjs/models/responsesoutputitemfilesearchcall.js.map +1 -1
- package/dist/commonjs/models/responsesoutputitemreasoning.d.ts +6 -16
- package/dist/commonjs/models/responsesoutputitemreasoning.d.ts.map +1 -1
- package/dist/commonjs/models/responsesoutputitemreasoning.js +10 -2
- package/dist/commonjs/models/responsesoutputitemreasoning.js.map +1 -1
- package/dist/commonjs/models/responsesstreamchunkunion.d.ts +31 -81
- package/dist/commonjs/models/responsesstreamchunkunion.d.ts.map +1 -1
- package/dist/commonjs/models/responsesstreamchunkunion.js +55 -12
- package/dist/commonjs/models/responsesstreamchunkunion.js.map +1 -1
- package/dist/commonjs/models/responseswebsearchcalloutput.d.ts +6 -16
- package/dist/commonjs/models/responseswebsearchcalloutput.d.ts.map +1 -1
- package/dist/commonjs/models/responseswebsearchcalloutput.js +10 -2
- package/dist/commonjs/models/responseswebsearchcalloutput.js.map +1 -1
- package/dist/commonjs/models/responsetextverbosity.d.ts +6 -14
- package/dist/commonjs/models/responsetextverbosity.d.ts.map +1 -1
- package/dist/commonjs/models/responsetextverbosity.js +10 -2
- package/dist/commonjs/models/responsetextverbosity.js.map +1 -1
- package/dist/commonjs/sdk/oauth.d.ts +27 -0
- package/dist/commonjs/sdk/oauth.d.ts.map +1 -1
- package/dist/commonjs/sdk/oauth.js +43 -0
- package/dist/commonjs/sdk/oauth.js.map +1 -1
- package/dist/esm/funcs/betaResponsesSend.js +1 -1
- package/dist/esm/funcs/betaResponsesSend.js.map +1 -1
- package/dist/esm/funcs/chatSend.js +1 -1
- package/dist/esm/funcs/chatSend.js.map +1 -1
- package/dist/esm/funcs/custom/oAuthCreateAuthorizationUrl.d.ts +43 -0
- package/dist/esm/funcs/custom/oAuthCreateAuthorizationUrl.d.ts.map +1 -0
- package/dist/esm/funcs/custom/oAuthCreateAuthorizationUrl.js +44 -0
- package/dist/esm/funcs/custom/oAuthCreateAuthorizationUrl.js.map +1 -0
- package/dist/esm/funcs/custom/oAuthCreateAuthorizationUrl.test.d.ts +2 -0
- package/dist/esm/funcs/custom/oAuthCreateAuthorizationUrl.test.d.ts.map +1 -0
- package/dist/esm/funcs/custom/oAuthCreateAuthorizationUrl.test.js +211 -0
- package/dist/esm/funcs/custom/oAuthCreateAuthorizationUrl.test.js.map +1 -0
- package/dist/esm/funcs/custom/oAuthCreateSHA256CodeChallenge.d.ts +35 -0
- package/dist/esm/funcs/custom/oAuthCreateSHA256CodeChallenge.d.ts.map +1 -0
- package/dist/esm/funcs/custom/oAuthCreateSHA256CodeChallenge.js +69 -0
- package/dist/esm/funcs/custom/oAuthCreateSHA256CodeChallenge.js.map +1 -0
- package/dist/esm/funcs/custom/oAuthCreateSHA256CodeChallenge.test.d.ts +2 -0
- package/dist/esm/funcs/custom/oAuthCreateSHA256CodeChallenge.test.d.ts.map +1 -0
- package/dist/esm/funcs/custom/oAuthCreateSHA256CodeChallenge.test.js +162 -0
- package/dist/esm/funcs/custom/oAuthCreateSHA256CodeChallenge.test.js.map +1 -0
- package/dist/esm/funcs/modelsList.js +1 -1
- package/dist/esm/funcs/modelsList.js.map +1 -1
- package/dist/esm/lib/config.d.ts +3 -3
- package/dist/esm/lib/config.js +3 -3
- package/dist/esm/lib/config.js.map +1 -1
- package/dist/esm/models/chatgenerationparams.d.ts +16 -42
- package/dist/esm/models/chatgenerationparams.d.ts.map +1 -1
- package/dist/esm/models/chatgenerationparams.js +27 -6
- package/dist/esm/models/chatgenerationparams.js.map +1 -1
- package/dist/esm/models/chatmessagecontentitemaudio.d.ts +6 -22
- package/dist/esm/models/chatmessagecontentitemaudio.d.ts.map +1 -1
- package/dist/esm/models/chatmessagecontentitemaudio.js +10 -2
- package/dist/esm/models/chatmessagecontentitemaudio.js.map +1 -1
- package/dist/esm/models/chatmessagecontentitemimage.d.ts +6 -14
- package/dist/esm/models/chatmessagecontentitemimage.d.ts.map +1 -1
- package/dist/esm/models/chatmessagecontentitemimage.js +10 -2
- package/dist/esm/models/chatmessagecontentitemimage.js.map +1 -1
- package/dist/esm/models/chatresponsechoice.d.ts +6 -18
- package/dist/esm/models/chatresponsechoice.d.ts.map +1 -1
- package/dist/esm/models/chatresponsechoice.js +10 -2
- package/dist/esm/models/chatresponsechoice.js.map +1 -1
- package/dist/esm/models/chatstreamingchoice.d.ts +6 -18
- package/dist/esm/models/chatstreamingchoice.d.ts.map +1 -1
- package/dist/esm/models/chatstreamingchoice.js +10 -2
- package/dist/esm/models/chatstreamingchoice.js.map +1 -1
- package/dist/esm/models/completionfinishreason.d.ts +6 -14
- package/dist/esm/models/completionfinishreason.d.ts.map +1 -1
- package/dist/esm/models/completionfinishreason.js +10 -2
- package/dist/esm/models/completionfinishreason.js.map +1 -1
- package/dist/esm/models/endpointslist.d.ts +21 -269
- package/dist/esm/models/endpointslist.d.ts.map +1 -1
- package/dist/esm/models/endpointslist.js +37 -8
- package/dist/esm/models/endpointslist.js.map +1 -1
- package/dist/esm/models/errorresponse.d.ts +6 -148
- package/dist/esm/models/errorresponse.d.ts.map +1 -1
- package/dist/esm/models/errorresponse.js +10 -2
- package/dist/esm/models/errorresponse.js.map +1 -1
- package/dist/esm/models/modelslist.d.ts +26 -178
- package/dist/esm/models/modelslist.d.ts.map +1 -1
- package/dist/esm/models/modelslist.js +46 -11
- package/dist/esm/models/modelslist.js.map +1 -1
- package/dist/esm/models/operations/addcoinbasecharge.d.ts +6 -14
- package/dist/esm/models/operations/addcoinbasecharge.d.ts.map +1 -1
- package/dist/esm/models/operations/addcoinbasecharge.js +9 -2
- package/dist/esm/models/operations/addcoinbasecharge.js.map +1 -1
- package/dist/esm/models/operations/create.d.ts +6 -14
- package/dist/esm/models/operations/create.d.ts.map +1 -1
- package/dist/esm/models/operations/create.js +10 -2
- package/dist/esm/models/operations/create.js.map +1 -1
- package/dist/esm/models/operations/createauthorizationcode.d.ts +6 -12
- package/dist/esm/models/operations/createauthorizationcode.d.ts.map +1 -1
- package/dist/esm/models/operations/createauthorizationcode.js +9 -2
- package/dist/esm/models/operations/createauthorizationcode.js.map +1 -1
- package/dist/esm/models/operations/exchangeauthorizationcode.d.ts +6 -12
- package/dist/esm/models/operations/exchangeauthorizationcode.d.ts.map +1 -1
- package/dist/esm/models/operations/exchangeauthorizationcode.js +9 -2
- package/dist/esm/models/operations/exchangeauthorizationcode.js.map +1 -1
- package/dist/esm/models/operations/generate.d.ts +37 -569
- package/dist/esm/models/operations/generate.d.ts.map +1 -1
- package/dist/esm/models/operations/generate.js +55 -12
- package/dist/esm/models/operations/generate.js.map +1 -1
- package/dist/esm/models/operations/getmetadata.d.ts +6 -12
- package/dist/esm/models/operations/getmetadata.d.ts.map +1 -1
- package/dist/esm/models/operations/getmetadata.js +9 -2
- package/dist/esm/models/operations/getmetadata.js.map +1 -1
- package/dist/esm/models/operations/getparameters.d.ts +11 -189
- package/dist/esm/models/operations/getparameters.d.ts.map +1 -1
- package/dist/esm/models/operations/getparameters.js +19 -4
- package/dist/esm/models/operations/getparameters.js.map +1 -1
- package/dist/esm/models/operations/list.d.ts +21 -125
- package/dist/esm/models/operations/list.d.ts.map +1 -1
- package/dist/esm/models/operations/list.js +36 -8
- package/dist/esm/models/operations/list.js.map +1 -1
- package/dist/esm/models/operations/previewzdr.d.ts +21 -269
- package/dist/esm/models/operations/previewzdr.d.ts.map +1 -1
- package/dist/esm/models/operations/previewzdr.js +38 -9
- package/dist/esm/models/operations/previewzdr.js.map +1 -1
- package/dist/esm/models/operations/sendresponsesrequest.d.ts +57 -621
- package/dist/esm/models/operations/sendresponsesrequest.d.ts.map +1 -1
- package/dist/esm/models/operations/sendresponsesrequest.js +88 -20
- package/dist/esm/models/operations/sendresponsesrequest.js.map +1 -1
- package/dist/esm/models/operations/update.d.ts +6 -14
- package/dist/esm/models/operations/update.d.ts.map +1 -1
- package/dist/esm/models/operations/update.js +10 -2
- package/dist/esm/models/operations/update.js.map +1 -1
- package/dist/esm/models/responsefunctioncallstatus.d.ts +6 -14
- package/dist/esm/models/responsefunctioncallstatus.d.ts.map +1 -1
- package/dist/esm/models/responsefunctioncallstatus.js +10 -2
- package/dist/esm/models/responsefunctioncallstatus.js.map +1 -1
- package/dist/esm/models/responseimagegenerationcallstatus.d.ts +6 -16
- package/dist/esm/models/responseimagegenerationcallstatus.d.ts.map +1 -1
- package/dist/esm/models/responseimagegenerationcallstatus.js +10 -2
- package/dist/esm/models/responseimagegenerationcallstatus.js.map +1 -1
- package/dist/esm/models/responseincludable.d.ts +6 -18
- package/dist/esm/models/responseincludable.d.ts.map +1 -1
- package/dist/esm/models/responseincludable.js +10 -2
- package/dist/esm/models/responseincludable.js.map +1 -1
- package/dist/esm/models/responseinputimagedetail.d.ts +6 -14
- package/dist/esm/models/responseinputimagedetail.d.ts.map +1 -1
- package/dist/esm/models/responseinputimagedetail.js +10 -2
- package/dist/esm/models/responseinputimagedetail.js.map +1 -1
- package/dist/esm/models/responsereasoningconfig.d.ts +6 -16
- package/dist/esm/models/responsereasoningconfig.d.ts.map +1 -1
- package/dist/esm/models/responsereasoningconfig.js +10 -2
- package/dist/esm/models/responsereasoningconfig.js.map +1 -1
- package/dist/esm/models/responsereasoningsummarymode.d.ts +6 -14
- package/dist/esm/models/responsereasoningsummarymode.d.ts.map +1 -1
- package/dist/esm/models/responsereasoningsummarymode.js +10 -2
- package/dist/esm/models/responsereasoningsummarymode.js.map +1 -1
- package/dist/esm/models/responsesincompletedetails.d.ts +6 -12
- package/dist/esm/models/responsesincompletedetails.d.ts.map +1 -1
- package/dist/esm/models/responsesincompletedetails.js +10 -2
- package/dist/esm/models/responsesincompletedetails.js.map +1 -1
- package/dist/esm/models/responsesnonstreamingresponse.d.ts +21 -61
- package/dist/esm/models/responsesnonstreamingresponse.d.ts.map +1 -1
- package/dist/esm/models/responsesnonstreamingresponse.js +35 -8
- package/dist/esm/models/responsesnonstreamingresponse.js.map +1 -1
- package/dist/esm/models/responsesoutputitemfilesearchcall.d.ts +6 -16
- package/dist/esm/models/responsesoutputitemfilesearchcall.d.ts.map +1 -1
- package/dist/esm/models/responsesoutputitemfilesearchcall.js +9 -2
- package/dist/esm/models/responsesoutputitemfilesearchcall.js.map +1 -1
- package/dist/esm/models/responsesoutputitemreasoning.d.ts +6 -16
- package/dist/esm/models/responsesoutputitemreasoning.d.ts.map +1 -1
- package/dist/esm/models/responsesoutputitemreasoning.js +10 -2
- package/dist/esm/models/responsesoutputitemreasoning.js.map +1 -1
- package/dist/esm/models/responsesstreamchunkunion.d.ts +31 -81
- package/dist/esm/models/responsesstreamchunkunion.d.ts.map +1 -1
- package/dist/esm/models/responsesstreamchunkunion.js +55 -12
- package/dist/esm/models/responsesstreamchunkunion.js.map +1 -1
- package/dist/esm/models/responseswebsearchcalloutput.d.ts +6 -16
- package/dist/esm/models/responseswebsearchcalloutput.d.ts.map +1 -1
- package/dist/esm/models/responseswebsearchcalloutput.js +10 -2
- package/dist/esm/models/responseswebsearchcalloutput.js.map +1 -1
- package/dist/esm/models/responsetextverbosity.d.ts +6 -14
- package/dist/esm/models/responsetextverbosity.d.ts.map +1 -1
- package/dist/esm/models/responsetextverbosity.js +10 -2
- package/dist/esm/models/responsetextverbosity.js.map +1 -1
- package/dist/esm/sdk/oauth.d.ts +27 -0
- package/dist/esm/sdk/oauth.d.ts.map +1 -1
- package/dist/esm/sdk/oauth.js +43 -0
- package/dist/esm/sdk/oauth.js.map +1 -1
- package/jsr.json +1 -1
- package/package.json +3 -2
- package/src/funcs/betaResponsesSend.ts +1 -1
- package/src/funcs/chatSend.ts +1 -1
- package/src/funcs/custom/oAuthCreateAuthorizationUrl.test.ts +265 -0
- package/src/funcs/custom/oAuthCreateAuthorizationUrl.ts +66 -0
- package/src/funcs/custom/oAuthCreateSHA256CodeChallenge.test.ts +189 -0
- package/src/funcs/custom/oAuthCreateSHA256CodeChallenge.ts +90 -0
- package/src/funcs/modelsList.ts +1 -1
- package/src/lib/config.ts +3 -3
- package/src/models/chatgenerationparams.ts +59 -20
- package/src/models/chatmessagecontentitemaudio.ts +23 -8
- package/src/models/chatmessagecontentitemimage.ts +16 -6
- package/src/models/chatresponsechoice.ts +23 -8
- package/src/models/chatstreamingchoice.ts +23 -8
- package/src/models/completionfinishreason.ts +23 -8
- package/src/models/endpointslist.ts +77 -25
- package/src/models/errorresponse.ts +23 -8
- package/src/models/modelslist.ts +95 -32
- package/src/models/operations/addcoinbasecharge.ts +17 -6
- package/src/models/operations/create.ts +23 -8
- package/src/models/operations/createauthorizationcode.ts +20 -6
- package/src/models/operations/exchangeauthorizationcode.ts +23 -6
- package/src/models/operations/generate.ts +114 -41
- package/src/models/operations/getmetadata.ts +17 -6
- package/src/models/operations/getparameters.ts +41 -15
- package/src/models/operations/list.ts +77 -25
- package/src/models/operations/previewzdr.ts +70 -25
- package/src/models/operations/sendresponsesrequest.ts +179 -63
- package/src/models/operations/update.ts +23 -8
- package/src/models/responsefunctioncallstatus.ts +23 -8
- package/src/models/responseimagegenerationcallstatus.ts +23 -8
- package/src/models/responseincludable.ts +23 -8
- package/src/models/responseinputimagedetail.ts +23 -8
- package/src/models/responsereasoningconfig.ts +23 -8
- package/src/models/responsereasoningsummarymode.ts +23 -8
- package/src/models/responsesincompletedetails.ts +23 -8
- package/src/models/responsesnonstreamingresponse.ts +78 -25
- package/src/models/responsesoutputitemfilesearchcall.ts +24 -8
- package/src/models/responsesoutputitemreasoning.ts +24 -8
- package/src/models/responsesstreamchunkunion.ts +114 -43
- package/src/models/responseswebsearchcalloutput.ts +24 -8
- package/src/models/responsetextverbosity.ts +23 -8
- package/src/sdk/oauth.ts +60 -0
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"responsetextverbosity.d.ts","sourceRoot":"","sources":["../../../src/models/responsetextverbosity.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,CAAC,MAAM,KAAK,CAAC;AACzB,OAAO,
|
|
1
|
+
{"version":3,"file":"responsetextverbosity.d.ts","sourceRoot":"","sources":["../../../src/models/responsetextverbosity.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,CAAC,MAAM,KAAK,CAAC;AACzB,OAAO,EAEL,QAAQ,EAET,MAAM,mBAAmB,CAAC;AAE3B,eAAO,MAAM,qBAAqB;;;;CAIxB,CAAC;AACX,MAAM,MAAM,qBAAqB,GAAG,QAAQ,CAAC,OAAO,qBAAqB,CAAC,CAAC;AAE3E,gBAAgB;AAChB,eAAO,MAAM,mCAAmC,EAAE,CAAC,CAAC,OAAO,CACzD,qBAAqB,EACrB,CAAC,CAAC,UAAU,EACZ,OAAO,CAKL,CAAC;AAEL,gBAAgB;AAChB,eAAO,MAAM,oCAAoC,EAAE,CAAC,CAAC,OAAO,CAC1D,qBAAqB,EACrB,CAAC,CAAC,UAAU,EACZ,qBAAqB,CAIrB,CAAC;AAEH;;;GAGG;AACH,yBAAiB,sBAAsB,CAAC;IACtC,qEAAqE;IAC9D,MAAM,aAAa,yDAAsC,CAAC;IACjE,sEAAsE;IAC/D,MAAM,cAAc,uEAAuC,CAAC;CACpE"}
|
|
@@ -2,15 +2,23 @@
|
|
|
2
2
|
* Code generated by Speakeasy (https://speakeasy.com). DO NOT EDIT.
|
|
3
3
|
*/
|
|
4
4
|
import * as z from "zod";
|
|
5
|
+
import { catchUnrecognizedEnum, } from "../types/enums.js";
|
|
5
6
|
export const ResponseTextVerbosity = {
|
|
6
7
|
High: "high",
|
|
7
8
|
Low: "low",
|
|
8
9
|
Medium: "medium",
|
|
9
10
|
};
|
|
10
11
|
/** @internal */
|
|
11
|
-
export const ResponseTextVerbosity$inboundSchema = z
|
|
12
|
+
export const ResponseTextVerbosity$inboundSchema = z
|
|
13
|
+
.union([
|
|
14
|
+
z.nativeEnum(ResponseTextVerbosity),
|
|
15
|
+
z.string().transform(catchUnrecognizedEnum),
|
|
16
|
+
]);
|
|
12
17
|
/** @internal */
|
|
13
|
-
export const ResponseTextVerbosity$outboundSchema =
|
|
18
|
+
export const ResponseTextVerbosity$outboundSchema = z.union([
|
|
19
|
+
z.nativeEnum(ResponseTextVerbosity),
|
|
20
|
+
z.string().and(z.custom()),
|
|
21
|
+
]);
|
|
14
22
|
/**
|
|
15
23
|
* @internal
|
|
16
24
|
* @deprecated This namespace will be removed in future versions. Use schemas and types that are exported directly from this module.
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"responsetextverbosity.js","sourceRoot":"","sources":["../../../src/models/responsetextverbosity.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,KAAK,CAAC,MAAM,KAAK,CAAC;
|
|
1
|
+
{"version":3,"file":"responsetextverbosity.js","sourceRoot":"","sources":["../../../src/models/responsetextverbosity.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,KAAK,CAAC,MAAM,KAAK,CAAC;AACzB,OAAO,EACL,qBAAqB,GAGtB,MAAM,mBAAmB,CAAC;AAE3B,MAAM,CAAC,MAAM,qBAAqB,GAAG;IACnC,IAAI,EAAE,MAAM;IACZ,GAAG,EAAE,KAAK;IACV,MAAM,EAAE,QAAQ;CACR,CAAC;AAGX,gBAAgB;AAChB,MAAM,CAAC,MAAM,mCAAmC,GAI5C,CAAC;KACF,KAAK,CAAC;IACL,CAAC,CAAC,UAAU,CAAC,qBAAqB,CAAC;IACnC,CAAC,CAAC,MAAM,EAAE,CAAC,SAAS,CAAC,qBAAqB,CAAC;CAC5C,CAAC,CAAC;AAEL,gBAAgB;AAChB,MAAM,CAAC,MAAM,oCAAoC,GAI7C,CAAC,CAAC,KAAK,CAAC;IACV,CAAC,CAAC,UAAU,CAAC,qBAAqB,CAAC;IACnC,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,MAAM,EAAwB,CAAC;CACjD,CAAC,CAAC;AAEH;;;GAGG;AACH,MAAM,KAAW,sBAAsB,CAKtC;AALD,WAAiB,sBAAsB;IACrC,qEAAqE;IACxD,oCAAa,GAAG,mCAAmC,CAAC;IACjE,sEAAsE;IACzD,qCAAc,GAAG,oCAAoC,CAAC;AACrE,CAAC,EALgB,sBAAsB,KAAtB,sBAAsB,QAKtC"}
|
package/dist/esm/sdk/oauth.d.ts
CHANGED
|
@@ -1,6 +1,33 @@
|
|
|
1
1
|
import { ClientSDK, RequestOptions } from "../lib/sdks.js";
|
|
2
2
|
import * as operations from "../models/operations/index.js";
|
|
3
|
+
import { CreateAuthorizationUrlRequest } from "../funcs/custom/oAuthCreateAuthorizationUrl.js";
|
|
4
|
+
import { CreateSHA256CodeChallengeRequest, CreateSHA256CodeChallengeResponse } from "../funcs/custom/oAuthCreateSHA256CodeChallenge.js";
|
|
3
5
|
export declare class OAuth extends ClientSDK {
|
|
6
|
+
/**
|
|
7
|
+
* Generate a OAuth2 authorization URL
|
|
8
|
+
*
|
|
9
|
+
* @remarks
|
|
10
|
+
* Generates a URL to redirect users to for authorizing your application. The
|
|
11
|
+
* URL includes the provided callback URL and, if applicable, the code
|
|
12
|
+
* challenge parameters for PKCE.
|
|
13
|
+
*
|
|
14
|
+
* @see {@link https://openrouter.ai/docs/use-cases/oauth-pkce}
|
|
15
|
+
*/
|
|
16
|
+
createAuthorizationUrl(request: CreateAuthorizationUrlRequest): Promise<string>;
|
|
17
|
+
/**
|
|
18
|
+
* Generate a SHA-256 code challenge for PKCE
|
|
19
|
+
*
|
|
20
|
+
* @remarks
|
|
21
|
+
* Generates a SHA-256 code challenge and corresponding code verifier for use
|
|
22
|
+
* in the PKCE extension to OAuth2. If no code verifier is provided, a random
|
|
23
|
+
* one will be generated according to RFC 7636 (32 random bytes, base64url
|
|
24
|
+
* encoded). If a code verifier is provided, it must be 43-128 characters and
|
|
25
|
+
* contain only unreserved characters [A-Za-z0-9-._~].
|
|
26
|
+
*
|
|
27
|
+
* @see {@link https://openrouter.ai/docs/use-cases/oauth-pkce}
|
|
28
|
+
* @see {@link https://datatracker.ietf.org/doc/html/rfc7636}
|
|
29
|
+
*/
|
|
30
|
+
createSHA256CodeChallenge(request?: CreateSHA256CodeChallengeRequest): Promise<CreateSHA256CodeChallengeResponse>;
|
|
4
31
|
/**
|
|
5
32
|
* Exchange authorization code for API key
|
|
6
33
|
*
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"oauth.d.ts","sourceRoot":"","sources":["../../../src/sdk/oauth.ts"],"names":[],"mappings":"AAMA,OAAO,EAAE,SAAS,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAC;AAC3D,OAAO,KAAK,UAAU,MAAM,+BAA+B,CAAC;AAG5D,qBAAa,KAAM,SAAQ,SAAS;
|
|
1
|
+
{"version":3,"file":"oauth.d.ts","sourceRoot":"","sources":["../../../src/sdk/oauth.ts"],"names":[],"mappings":"AAMA,OAAO,EAAE,SAAS,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAC;AAC3D,OAAO,KAAK,UAAU,MAAM,+BAA+B,CAAC;AAG5D,OAAO,EACL,6BAA6B,EAE9B,MAAM,gDAAgD,CAAC;AACxD,OAAO,EACL,gCAAgC,EAChC,iCAAiC,EAElC,MAAM,mDAAmD,CAAC;AAG3D,qBAAa,KAAM,SAAQ,SAAS;IAElC;;;;;;;;;OASG;IACG,sBAAsB,CAC1B,OAAO,EAAE,6BAA6B,GACrC,OAAO,CAAC,MAAM,CAAC;IAUlB;;;;;;;;;;;;OAYG;IACG,yBAAyB,CAC7B,OAAO,GAAE,gCAAqC,GAC7C,OAAO,CAAC,iCAAiC,CAAC;IAW7C;;;;;OAKG;IACG,yBAAyB,CAC7B,OAAO,EAAE,UAAU,CAAC,gCAAgC,EACpD,OAAO,CAAC,EAAE,cAAc,GACvB,OAAO,CAAC,UAAU,CAAC,iCAAiC,CAAC;IAQxD;;;;;OAKG;IACG,uBAAuB,CAC3B,OAAO,EAAE,UAAU,CAAC,8BAA8B,EAClD,OAAO,CAAC,EAAE,cAAc,GACvB,OAAO,CAAC,UAAU,CAAC,+BAA+B,CAAC;CAOvD"}
|
package/dist/esm/sdk/oauth.js
CHANGED
|
@@ -5,7 +5,50 @@ import { oAuthCreateAuthorizationCode } from "../funcs/oAuthCreateAuthorizationC
|
|
|
5
5
|
import { oAuthExchangeAuthorizationCode } from "../funcs/oAuthExchangeAuthorizationCode.js";
|
|
6
6
|
import { ClientSDK } from "../lib/sdks.js";
|
|
7
7
|
import { unwrapAsync } from "../types/fp.js";
|
|
8
|
+
// #region imports
|
|
9
|
+
import { oAuthCreateAuthorizationUrl, } from "../funcs/custom/oAuthCreateAuthorizationUrl.js";
|
|
10
|
+
import { oAuthCreateSHA256CodeChallenge, } from "../funcs/custom/oAuthCreateSHA256CodeChallenge.js";
|
|
11
|
+
// #endregion imports
|
|
8
12
|
export class OAuth extends ClientSDK {
|
|
13
|
+
// #region sdk-class-body
|
|
14
|
+
/**
|
|
15
|
+
* Generate a OAuth2 authorization URL
|
|
16
|
+
*
|
|
17
|
+
* @remarks
|
|
18
|
+
* Generates a URL to redirect users to for authorizing your application. The
|
|
19
|
+
* URL includes the provided callback URL and, if applicable, the code
|
|
20
|
+
* challenge parameters for PKCE.
|
|
21
|
+
*
|
|
22
|
+
* @see {@link https://openrouter.ai/docs/use-cases/oauth-pkce}
|
|
23
|
+
*/
|
|
24
|
+
async createAuthorizationUrl(request) {
|
|
25
|
+
const result = oAuthCreateAuthorizationUrl(this, request);
|
|
26
|
+
if (!result.ok) {
|
|
27
|
+
throw result.error;
|
|
28
|
+
}
|
|
29
|
+
return result.value;
|
|
30
|
+
}
|
|
31
|
+
/**
|
|
32
|
+
* Generate a SHA-256 code challenge for PKCE
|
|
33
|
+
*
|
|
34
|
+
* @remarks
|
|
35
|
+
* Generates a SHA-256 code challenge and corresponding code verifier for use
|
|
36
|
+
* in the PKCE extension to OAuth2. If no code verifier is provided, a random
|
|
37
|
+
* one will be generated according to RFC 7636 (32 random bytes, base64url
|
|
38
|
+
* encoded). If a code verifier is provided, it must be 43-128 characters and
|
|
39
|
+
* contain only unreserved characters [A-Za-z0-9-._~].
|
|
40
|
+
*
|
|
41
|
+
* @see {@link https://openrouter.ai/docs/use-cases/oauth-pkce}
|
|
42
|
+
* @see {@link https://datatracker.ietf.org/doc/html/rfc7636}
|
|
43
|
+
*/
|
|
44
|
+
async createSHA256CodeChallenge(request = {}) {
|
|
45
|
+
const result = await oAuthCreateSHA256CodeChallenge(request);
|
|
46
|
+
if (!result.ok) {
|
|
47
|
+
throw result.error;
|
|
48
|
+
}
|
|
49
|
+
return result.value;
|
|
50
|
+
}
|
|
51
|
+
// #endregion sdk-class-body
|
|
9
52
|
/**
|
|
10
53
|
* Exchange authorization code for API key
|
|
11
54
|
*
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"oauth.js","sourceRoot":"","sources":["../../../src/sdk/oauth.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EAAE,4BAA4B,EAAE,MAAM,0CAA0C,CAAC;AACxF,OAAO,EAAE,8BAA8B,EAAE,MAAM,4CAA4C,CAAC;AAC5F,OAAO,EAAE,SAAS,EAAkB,MAAM,gBAAgB,CAAC;AAE3D,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;
|
|
1
|
+
{"version":3,"file":"oauth.js","sourceRoot":"","sources":["../../../src/sdk/oauth.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EAAE,4BAA4B,EAAE,MAAM,0CAA0C,CAAC;AACxF,OAAO,EAAE,8BAA8B,EAAE,MAAM,4CAA4C,CAAC;AAC5F,OAAO,EAAE,SAAS,EAAkB,MAAM,gBAAgB,CAAC;AAE3D,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAC7C,kBAAkB;AAClB,OAAO,EAEL,2BAA2B,GAC5B,MAAM,gDAAgD,CAAC;AACxD,OAAO,EAGL,8BAA8B,GAC/B,MAAM,mDAAmD,CAAC;AAC3D,qBAAqB;AAErB,MAAM,OAAO,KAAM,SAAQ,SAAS;IAClC,yBAAyB;IACzB;;;;;;;;;OASG;IACH,KAAK,CAAC,sBAAsB,CAC1B,OAAsC;QAEtC,MAAM,MAAM,GAAG,2BAA2B,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;QAE1D,IAAI,CAAC,MAAM,CAAC,EAAE,EAAE,CAAC;YACf,MAAM,MAAM,CAAC,KAAK,CAAC;QACrB,CAAC;QAED,OAAO,MAAM,CAAC,KAAK,CAAC;IACtB,CAAC;IAED;;;;;;;;;;;;OAYG;IACH,KAAK,CAAC,yBAAyB,CAC7B,UAA4C,EAAE;QAE9C,MAAM,MAAM,GAAG,MAAM,8BAA8B,CAAC,OAAO,CAAC,CAAC;QAE7D,IAAI,CAAC,MAAM,CAAC,EAAE,EAAE,CAAC;YACf,MAAM,MAAM,CAAC,KAAK,CAAC;QACrB,CAAC;QAED,OAAO,MAAM,CAAC,KAAK,CAAC;IACtB,CAAC;IACD,4BAA4B;IAE5B;;;;;OAKG;IACH,KAAK,CAAC,yBAAyB,CAC7B,OAAoD,EACpD,OAAwB;QAExB,OAAO,WAAW,CAAC,8BAA8B,CAC/C,IAAI,EACJ,OAAO,EACP,OAAO,CACR,CAAC,CAAC;IACL,CAAC;IAED;;;;;OAKG;IACH,KAAK,CAAC,uBAAuB,CAC3B,OAAkD,EAClD,OAAwB;QAExB,OAAO,WAAW,CAAC,4BAA4B,CAC7C,IAAI,EACJ,OAAO,EACP,OAAO,CACR,CAAC,CAAC;IACL,CAAC;CACF"}
|
package/jsr.json
CHANGED
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@openrouter/sdk",
|
|
3
|
-
"version": "0.0.0-beta.
|
|
3
|
+
"version": "0.0.0-beta.39",
|
|
4
4
|
"author": "OpenRouter",
|
|
5
5
|
"type": "module",
|
|
6
6
|
"tshy": {
|
|
@@ -53,7 +53,8 @@
|
|
|
53
53
|
"globals": "^15.14.0",
|
|
54
54
|
"tshy": "^2.0.0",
|
|
55
55
|
"typescript": "~5.8.3",
|
|
56
|
-
"typescript-eslint": "^8.26.0"
|
|
56
|
+
"typescript-eslint": "^8.26.0",
|
|
57
|
+
"vitest": "^3.2.4"
|
|
57
58
|
},
|
|
58
59
|
"dependencies": {
|
|
59
60
|
"zod": "^3.20.0"
|
|
@@ -149,7 +149,7 @@ async function $do(
|
|
|
149
149
|
|
|
150
150
|
const headers = new Headers(compactMap({
|
|
151
151
|
"Content-Type": "application/json",
|
|
152
|
-
Accept: "application/json
|
|
152
|
+
Accept: request?.stream ? "text/event-stream" : "application/json",
|
|
153
153
|
}));
|
|
154
154
|
|
|
155
155
|
const secConfig = await extractSecurity(client._options.apiKey);
|
package/src/funcs/chatSend.ts
CHANGED
|
@@ -148,7 +148,7 @@ async function $do(
|
|
|
148
148
|
|
|
149
149
|
const headers = new Headers(compactMap({
|
|
150
150
|
"Content-Type": "application/json",
|
|
151
|
-
Accept: "application/json
|
|
151
|
+
Accept: request?.stream ? "text/event-stream" : "application/json",
|
|
152
152
|
}));
|
|
153
153
|
|
|
154
154
|
const secConfig = await extractSecurity(client._options.apiKey);
|
|
@@ -0,0 +1,265 @@
|
|
|
1
|
+
import { describe, it, expect } from "vitest";
|
|
2
|
+
import { OpenRouterCore } from "../../core.js";
|
|
3
|
+
import { oAuthCreateAuthorizationUrl } from "./oAuthCreateAuthorizationUrl.js";
|
|
4
|
+
|
|
5
|
+
describe("oAuthCreateAuthorizationUrl", () => {
|
|
6
|
+
const createMockClient = (serverURL?: string) => {
|
|
7
|
+
return new OpenRouterCore({ serverURL });
|
|
8
|
+
};
|
|
9
|
+
|
|
10
|
+
it("should generate authorization URL with callback URL", () => {
|
|
11
|
+
const client = createMockClient("https://openrouter.ai/api/v1");
|
|
12
|
+
const result = oAuthCreateAuthorizationUrl(client, {
|
|
13
|
+
callbackUrl: "https://example.com/callback",
|
|
14
|
+
});
|
|
15
|
+
|
|
16
|
+
expect(result.ok).toBe(true);
|
|
17
|
+
if (result.ok) {
|
|
18
|
+
const url = new URL(result.value);
|
|
19
|
+
expect(url.searchParams.get("callback_url")).toBe(
|
|
20
|
+
"https://example.com/callback",
|
|
21
|
+
);
|
|
22
|
+
}
|
|
23
|
+
});
|
|
24
|
+
|
|
25
|
+
it("should generate authorization URL with URL object as callback", () => {
|
|
26
|
+
const client = createMockClient("https://openrouter.ai/api/v1");
|
|
27
|
+
const callbackUrl = new URL("https://example.com/callback");
|
|
28
|
+
const result = oAuthCreateAuthorizationUrl(client, {
|
|
29
|
+
callbackUrl,
|
|
30
|
+
});
|
|
31
|
+
|
|
32
|
+
expect(result.ok).toBe(true);
|
|
33
|
+
if (result.ok) {
|
|
34
|
+
const url = new URL(result.value);
|
|
35
|
+
expect(url.searchParams.get("callback_url")).toBe(
|
|
36
|
+
"https://example.com/callback",
|
|
37
|
+
);
|
|
38
|
+
}
|
|
39
|
+
});
|
|
40
|
+
|
|
41
|
+
it("should include code challenge with S256 method", () => {
|
|
42
|
+
const client = createMockClient("https://openrouter.ai/api/v1");
|
|
43
|
+
const result = oAuthCreateAuthorizationUrl(client, {
|
|
44
|
+
callbackUrl: "https://example.com/callback",
|
|
45
|
+
codeChallenge: "test-code-challenge-abc123",
|
|
46
|
+
codeChallengeMethod: "S256",
|
|
47
|
+
});
|
|
48
|
+
|
|
49
|
+
expect(result.ok).toBe(true);
|
|
50
|
+
if (result.ok) {
|
|
51
|
+
const url = new URL(result.value);
|
|
52
|
+
expect(url.searchParams.get("code_challenge")).toBe(
|
|
53
|
+
"test-code-challenge-abc123",
|
|
54
|
+
);
|
|
55
|
+
expect(url.searchParams.get("code_challenge_method")).toBe("S256");
|
|
56
|
+
}
|
|
57
|
+
});
|
|
58
|
+
|
|
59
|
+
it("should include code challenge with plain method", () => {
|
|
60
|
+
const client = createMockClient("https://openrouter.ai/api/v1");
|
|
61
|
+
const result = oAuthCreateAuthorizationUrl(client, {
|
|
62
|
+
callbackUrl: "https://example.com/callback",
|
|
63
|
+
codeChallenge: "plain-code-challenge",
|
|
64
|
+
codeChallengeMethod: "plain",
|
|
65
|
+
});
|
|
66
|
+
|
|
67
|
+
expect(result.ok).toBe(true);
|
|
68
|
+
if (result.ok) {
|
|
69
|
+
const url = new URL(result.value);
|
|
70
|
+
expect(url.searchParams.get("code_challenge")).toBe(
|
|
71
|
+
"plain-code-challenge",
|
|
72
|
+
);
|
|
73
|
+
expect(url.searchParams.get("code_challenge_method")).toBe("plain");
|
|
74
|
+
}
|
|
75
|
+
});
|
|
76
|
+
|
|
77
|
+
it("should include limit parameter when provided", () => {
|
|
78
|
+
const client = createMockClient("https://openrouter.ai/api/v1");
|
|
79
|
+
const result = oAuthCreateAuthorizationUrl(client, {
|
|
80
|
+
callbackUrl: "https://example.com/callback",
|
|
81
|
+
limit: 100,
|
|
82
|
+
});
|
|
83
|
+
|
|
84
|
+
expect(result.ok).toBe(true);
|
|
85
|
+
if (result.ok) {
|
|
86
|
+
const url = new URL(result.value);
|
|
87
|
+
expect(url.searchParams.get("limit")).toBe("100");
|
|
88
|
+
}
|
|
89
|
+
});
|
|
90
|
+
|
|
91
|
+
it("should handle callback URL with query parameters", () => {
|
|
92
|
+
const client = createMockClient("https://openrouter.ai/api/v1");
|
|
93
|
+
const result = oAuthCreateAuthorizationUrl(client, {
|
|
94
|
+
callbackUrl: "https://example.com/callback?state=abc123&redirect=true",
|
|
95
|
+
});
|
|
96
|
+
|
|
97
|
+
expect(result.ok).toBe(true);
|
|
98
|
+
if (result.ok) {
|
|
99
|
+
const url = new URL(result.value);
|
|
100
|
+
expect(url.searchParams.get("callback_url")).toBe(
|
|
101
|
+
"https://example.com/callback?state=abc123&redirect=true",
|
|
102
|
+
);
|
|
103
|
+
}
|
|
104
|
+
});
|
|
105
|
+
|
|
106
|
+
it("should handle callback URL with special characters", () => {
|
|
107
|
+
const client = createMockClient("https://openrouter.ai/api/v1");
|
|
108
|
+
const result = oAuthCreateAuthorizationUrl(client, {
|
|
109
|
+
callbackUrl: "https://example.com/callback?data=hello%20world",
|
|
110
|
+
});
|
|
111
|
+
|
|
112
|
+
expect(result.ok).toBe(true);
|
|
113
|
+
if (result.ok) {
|
|
114
|
+
const url = new URL(result.value);
|
|
115
|
+
expect(url.searchParams.get("callback_url")).toBe(
|
|
116
|
+
"https://example.com/callback?data=hello%20world",
|
|
117
|
+
);
|
|
118
|
+
}
|
|
119
|
+
});
|
|
120
|
+
|
|
121
|
+
it("should return error for invalid callback URL string", () => {
|
|
122
|
+
const client = createMockClient("https://openrouter.ai/api/v1");
|
|
123
|
+
const result = oAuthCreateAuthorizationUrl(client, {
|
|
124
|
+
callbackUrl: "not-a-valid-url" as any,
|
|
125
|
+
});
|
|
126
|
+
|
|
127
|
+
expect(result.ok).toBe(false);
|
|
128
|
+
if (!result.ok) {
|
|
129
|
+
expect(result.error).toBeDefined();
|
|
130
|
+
}
|
|
131
|
+
});
|
|
132
|
+
|
|
133
|
+
it("should handle callback URL with localhost", () => {
|
|
134
|
+
const client = createMockClient("https://openrouter.ai/api/v1");
|
|
135
|
+
const result = oAuthCreateAuthorizationUrl(client, {
|
|
136
|
+
callbackUrl: "http://localhost:3000/callback",
|
|
137
|
+
});
|
|
138
|
+
|
|
139
|
+
expect(result.ok).toBe(true);
|
|
140
|
+
if (result.ok) {
|
|
141
|
+
const url = new URL(result.value);
|
|
142
|
+
expect(url.searchParams.get("callback_url")).toBe(
|
|
143
|
+
"http://localhost:3000/callback",
|
|
144
|
+
);
|
|
145
|
+
}
|
|
146
|
+
});
|
|
147
|
+
|
|
148
|
+
it("should use default production server when no serverURL provided", () => {
|
|
149
|
+
const client = createMockClient();
|
|
150
|
+
const result = oAuthCreateAuthorizationUrl(client, {
|
|
151
|
+
callbackUrl: "https://example.com/callback",
|
|
152
|
+
});
|
|
153
|
+
|
|
154
|
+
expect(result.ok).toBe(true);
|
|
155
|
+
if (result.ok) {
|
|
156
|
+
const url = new URL(result.value);
|
|
157
|
+
expect(url.origin).toBe("https://openrouter.ai");
|
|
158
|
+
expect(url.pathname).toBe("/auth");
|
|
159
|
+
}
|
|
160
|
+
});
|
|
161
|
+
|
|
162
|
+
it("should use custom server URL when provided", () => {
|
|
163
|
+
const client = createMockClient("https://custom.example.com/api");
|
|
164
|
+
const result = oAuthCreateAuthorizationUrl(client, {
|
|
165
|
+
callbackUrl: "https://example.com/callback",
|
|
166
|
+
});
|
|
167
|
+
|
|
168
|
+
expect(result.ok).toBe(true);
|
|
169
|
+
if (result.ok) {
|
|
170
|
+
const url = new URL(result.value);
|
|
171
|
+
expect(url.origin).toBe("https://custom.example.com");
|
|
172
|
+
expect(url.pathname).toBe("/auth");
|
|
173
|
+
}
|
|
174
|
+
});
|
|
175
|
+
|
|
176
|
+
it("should preserve all parameters with PKCE", () => {
|
|
177
|
+
const client = createMockClient("https://openrouter.ai/api/v1");
|
|
178
|
+
const result = oAuthCreateAuthorizationUrl(client, {
|
|
179
|
+
callbackUrl: "https://example.com/callback?state=xyz",
|
|
180
|
+
codeChallenge: "challenge123",
|
|
181
|
+
codeChallengeMethod: "S256",
|
|
182
|
+
limit: 50,
|
|
183
|
+
});
|
|
184
|
+
|
|
185
|
+
expect(result.ok).toBe(true);
|
|
186
|
+
if (result.ok) {
|
|
187
|
+
const url = new URL(result.value);
|
|
188
|
+
expect(url.searchParams.get("callback_url")).toBe(
|
|
189
|
+
"https://example.com/callback?state=xyz",
|
|
190
|
+
);
|
|
191
|
+
expect(url.searchParams.get("code_challenge")).toBe("challenge123");
|
|
192
|
+
expect(url.searchParams.get("code_challenge_method")).toBe("S256");
|
|
193
|
+
expect(url.searchParams.get("limit")).toBe("50");
|
|
194
|
+
}
|
|
195
|
+
});
|
|
196
|
+
|
|
197
|
+
it("should handle callback URL with fragment", () => {
|
|
198
|
+
const client = createMockClient("https://openrouter.ai/api/v1");
|
|
199
|
+
const result = oAuthCreateAuthorizationUrl(client, {
|
|
200
|
+
callbackUrl: "https://example.com/callback#section",
|
|
201
|
+
});
|
|
202
|
+
|
|
203
|
+
expect(result.ok).toBe(true);
|
|
204
|
+
if (result.ok) {
|
|
205
|
+
const url = new URL(result.value);
|
|
206
|
+
expect(url.searchParams.get("callback_url")).toBe(
|
|
207
|
+
"https://example.com/callback#section",
|
|
208
|
+
);
|
|
209
|
+
}
|
|
210
|
+
});
|
|
211
|
+
|
|
212
|
+
it("should return error for invalid input types", () => {
|
|
213
|
+
const client = createMockClient("https://openrouter.ai/api/v1");
|
|
214
|
+
const result = oAuthCreateAuthorizationUrl(client, {
|
|
215
|
+
callbackUrl: 12345 as any,
|
|
216
|
+
});
|
|
217
|
+
|
|
218
|
+
expect(result.ok).toBe(false);
|
|
219
|
+
if (!result.ok) {
|
|
220
|
+
expect(result.error).toBeDefined();
|
|
221
|
+
}
|
|
222
|
+
});
|
|
223
|
+
|
|
224
|
+
it("should handle URL with port number in callback", () => {
|
|
225
|
+
const client = createMockClient("https://openrouter.ai/api/v1");
|
|
226
|
+
const result = oAuthCreateAuthorizationUrl(client, {
|
|
227
|
+
callbackUrl: "https://example.com:8443/callback",
|
|
228
|
+
});
|
|
229
|
+
|
|
230
|
+
expect(result.ok).toBe(true);
|
|
231
|
+
if (result.ok) {
|
|
232
|
+
const url = new URL(result.value);
|
|
233
|
+
expect(url.searchParams.get("callback_url")).toBe(
|
|
234
|
+
"https://example.com:8443/callback",
|
|
235
|
+
);
|
|
236
|
+
}
|
|
237
|
+
});
|
|
238
|
+
|
|
239
|
+
it("should not omit limit parameter when value is 0", () => {
|
|
240
|
+
const client = createMockClient("https://openrouter.ai/api/v1");
|
|
241
|
+
const result = oAuthCreateAuthorizationUrl(client, {
|
|
242
|
+
callbackUrl: "https://example.com/callback",
|
|
243
|
+
limit: 0,
|
|
244
|
+
});
|
|
245
|
+
|
|
246
|
+
expect(result.ok).toBe(true);
|
|
247
|
+
if (result.ok) {
|
|
248
|
+
const url = new URL(result.value);
|
|
249
|
+
expect(url.searchParams.get("limit")).toBe("0");
|
|
250
|
+
}
|
|
251
|
+
});
|
|
252
|
+
|
|
253
|
+
it("should omit limit parameter when not provided", () => {
|
|
254
|
+
const client = createMockClient("https://openrouter.ai/api/v1");
|
|
255
|
+
const result = oAuthCreateAuthorizationUrl(client, {
|
|
256
|
+
callbackUrl: "https://example.com/callback",
|
|
257
|
+
});
|
|
258
|
+
|
|
259
|
+
expect(result.ok).toBe(true);
|
|
260
|
+
if (result.ok) {
|
|
261
|
+
const url = new URL(result.value);
|
|
262
|
+
expect(url.searchParams.has("limit")).toBe(false);
|
|
263
|
+
}
|
|
264
|
+
});
|
|
265
|
+
});
|
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
import z from "zod/v3";
|
|
2
|
+
import { OpenRouterCore } from "../../core.js";
|
|
3
|
+
import { serverURLFromOptions } from "../../lib/config.js";
|
|
4
|
+
import { Result } from "../../types/fp.js";
|
|
5
|
+
|
|
6
|
+
const CreateAuthorizationUrlBaseSchema = z.object({
|
|
7
|
+
callbackUrl: z.union([z.string().url(), z.instanceof(URL)]),
|
|
8
|
+
limit: z.number().optional(),
|
|
9
|
+
});
|
|
10
|
+
|
|
11
|
+
const CreateAuthorizationurlParamsSchema = z.union([
|
|
12
|
+
CreateAuthorizationUrlBaseSchema.extend({
|
|
13
|
+
codeChallengeMethod: z.enum(["S256", "plain"]),
|
|
14
|
+
codeChallenge: z.string(),
|
|
15
|
+
}),
|
|
16
|
+
CreateAuthorizationUrlBaseSchema,
|
|
17
|
+
]);
|
|
18
|
+
|
|
19
|
+
export type CreateAuthorizationUrlRequest = z.infer<
|
|
20
|
+
typeof CreateAuthorizationurlParamsSchema
|
|
21
|
+
>;
|
|
22
|
+
|
|
23
|
+
/**
|
|
24
|
+
* Generate a OAuth2 authorization URL
|
|
25
|
+
*
|
|
26
|
+
* @remarks
|
|
27
|
+
* Generates a URL to redirect users to for authorizing your application. The
|
|
28
|
+
* URL includes the provided callback URL and, if applicable, the code
|
|
29
|
+
* challenge parameters for PKCE.
|
|
30
|
+
*
|
|
31
|
+
* @see {@link https://openrouter.ai/docs/use-cases/oauth-pkce}
|
|
32
|
+
*/
|
|
33
|
+
export function oAuthCreateAuthorizationUrl(
|
|
34
|
+
client: OpenRouterCore,
|
|
35
|
+
params: CreateAuthorizationUrlRequest,
|
|
36
|
+
): Result<string> {
|
|
37
|
+
const parsedParams = CreateAuthorizationurlParamsSchema.safeParse(params);
|
|
38
|
+
if (!parsedParams.success) return { ok: false, error: parsedParams.error };
|
|
39
|
+
|
|
40
|
+
const baseURL = serverURLFromOptions(client._options);
|
|
41
|
+
if (!baseURL) {
|
|
42
|
+
return { ok: false, error: new Error("No server URL configured") };
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
// Clone the URL to avoid mutating the original
|
|
46
|
+
const authURL = new URL("/auth", baseURL);
|
|
47
|
+
|
|
48
|
+
authURL.searchParams.set(
|
|
49
|
+
"callback_url",
|
|
50
|
+
parsedParams.data.callbackUrl.toString(),
|
|
51
|
+
);
|
|
52
|
+
|
|
53
|
+
if ("codeChallengeMethod" in parsedParams.data) {
|
|
54
|
+
authURL.searchParams.set("code_challenge", parsedParams.data.codeChallenge);
|
|
55
|
+
authURL.searchParams.set(
|
|
56
|
+
"code_challenge_method",
|
|
57
|
+
parsedParams.data.codeChallengeMethod,
|
|
58
|
+
);
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
if (parsedParams.data.limit !== undefined) {
|
|
62
|
+
authURL.searchParams.set("limit", parsedParams.data.limit.toString());
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
return { ok: true, value: authURL.toString() };
|
|
66
|
+
}
|