@shippo/shippo-mcp 2.0.3 → 2.0.18
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/README.md +1 -1
- package/bin/mcp-server.js +1907 -950
- package/bin/mcp-server.js.map +69 -47
- package/esm/funcs/addressesCreateV1.d.ts +17 -0
- package/esm/funcs/addressesCreateV1.d.ts.map +1 -0
- package/esm/funcs/addressesCreateV1.js +86 -0
- package/esm/funcs/addressesCreateV1.js.map +1 -0
- package/esm/funcs/addressesCreateV2.d.ts +18 -0
- package/esm/funcs/addressesCreateV2.d.ts.map +1 -0
- package/esm/funcs/addressesCreateV2.js +93 -0
- package/esm/funcs/addressesCreateV2.js.map +1 -0
- package/esm/funcs/addressesParse.d.ts +24 -0
- package/esm/funcs/addressesParse.d.ts.map +1 -0
- package/esm/funcs/addressesParse.js +96 -0
- package/esm/funcs/addressesParse.js.map +1 -0
- package/esm/funcs/addressesValidateV2.d.ts +24 -0
- package/esm/funcs/addressesValidateV2.d.ts.map +1 -0
- package/esm/funcs/addressesValidateV2.js +105 -0
- package/esm/funcs/addressesValidateV2.js.map +1 -0
- package/esm/funcs/ordersGetPackingSlip.d.ts +16 -0
- package/esm/funcs/ordersGetPackingSlip.d.ts.map +1 -0
- package/esm/funcs/ordersGetPackingSlip.js +90 -0
- package/esm/funcs/ordersGetPackingSlip.js.map +1 -0
- package/esm/lib/config.d.ts +3 -3
- package/esm/lib/config.js +3 -3
- package/esm/lib/config.js.map +1 -1
- package/esm/mcp-server/mcp-server.js +1 -1
- package/esm/mcp-server/mcp-server.js.map +1 -1
- package/esm/mcp-server/server.d.ts.map +1 -1
- package/esm/mcp-server/server.js +11 -3
- package/esm/mcp-server/server.js.map +1 -1
- package/esm/mcp-server/tools/addressesCreateV1.d.ts +7 -0
- package/esm/mcp-server/tools/addressesCreateV1.d.ts.map +1 -0
- package/esm/mcp-server/tools/addressesCreateV1.js +48 -0
- package/esm/mcp-server/tools/addressesCreateV1.js.map +1 -0
- package/esm/mcp-server/tools/addressesCreateV2.d.ts +7 -0
- package/esm/mcp-server/tools/addressesCreateV2.d.ts.map +1 -0
- package/esm/mcp-server/tools/addressesCreateV2.js +82 -0
- package/esm/mcp-server/tools/addressesCreateV2.js.map +1 -0
- package/esm/mcp-server/tools/addressesParse.d.ts +7 -0
- package/esm/mcp-server/tools/addressesParse.d.ts.map +1 -0
- package/esm/mcp-server/tools/addressesParse.js +66 -0
- package/esm/mcp-server/tools/addressesParse.js.map +1 -0
- package/esm/mcp-server/tools/addressesValidate.d.ts.map +1 -1
- package/esm/mcp-server/tools/addressesValidate.js +12 -3
- package/esm/mcp-server/tools/addressesValidate.js.map +1 -1
- package/esm/mcp-server/tools/addressesValidateV2.d.ts +7 -0
- package/esm/mcp-server/tools/addressesValidateV2.d.ts.map +1 -0
- package/esm/mcp-server/tools/addressesValidateV2.js +95 -0
- package/esm/mcp-server/tools/addressesValidateV2.js.map +1 -0
- package/esm/mcp-server/tools/ordersGetPackingSlip.d.ts +7 -0
- package/esm/mcp-server/tools/ordersGetPackingSlip.d.ts.map +1 -0
- package/esm/mcp-server/tools/ordersGetPackingSlip.js +66 -0
- package/esm/mcp-server/tools/ordersGetPackingSlip.js.map +1 -0
- package/esm/mcp-server/tools/ordersList.d.ts.map +1 -1
- package/esm/mcp-server/tools/ordersList.js +20 -2
- package/esm/mcp-server/tools/ordersList.js.map +1 -1
- package/esm/models/addressanalysisv2.d.ts +24 -0
- package/esm/models/addressanalysisv2.d.ts.map +1 -0
- package/esm/models/addressanalysisv2.js +22 -0
- package/esm/models/addressanalysisv2.js.map +1 -0
- package/esm/models/addresscreaterequestv2.d.ts +41 -0
- package/esm/models/addresscreaterequestv2.d.ts.map +1 -0
- package/esm/models/addresscreaterequestv2.js +35 -0
- package/esm/models/addresscreaterequestv2.js.map +1 -0
- package/esm/models/addressdatav2.d.ts +35 -0
- package/esm/models/addressdatav2.d.ts.map +1 -0
- package/esm/models/addressdatav2.js +32 -0
- package/esm/models/addressdatav2.js.map +1 -0
- package/esm/models/addressv2.d.ts +18 -0
- package/esm/models/addressv2.d.ts.map +1 -0
- package/esm/models/addressv2.js +17 -0
- package/esm/models/addressv2.js.map +1 -0
- package/esm/models/addressvalidationresults.d.ts.map +1 -1
- package/esm/models/addressvalidationresults.js +1 -2
- package/esm/models/addressvalidationresults.js.map +1 -1
- package/esm/models/addressvalidationresultv2.d.ts +16 -0
- package/esm/models/addressvalidationresultv2.d.ts.map +1 -0
- package/esm/models/addressvalidationresultv2.js +15 -0
- package/esm/models/addressvalidationresultv2.js.map +1 -0
- package/esm/models/addresswithmetadataresponse.d.ts +13 -0
- package/esm/models/addresswithmetadataresponse.d.ts.map +1 -0
- package/esm/models/addresswithmetadataresponse.js +12 -0
- package/esm/models/addresswithmetadataresponse.js.map +1 -0
- package/esm/models/batch.d.ts.map +1 -1
- package/esm/models/batch.js +1 -5
- package/esm/models/batch.js.map +1 -1
- package/esm/models/batchshipment.d.ts.map +1 -1
- package/esm/models/batchshipment.js +1 -4
- package/esm/models/batchshipment.js.map +1 -1
- package/esm/models/batchshipmentpaginatedlist.d.ts.map +1 -1
- package/esm/models/batchshipmentpaginatedlist.js +1 -2
- package/esm/models/batchshipmentpaginatedlist.js.map +1 -1
- package/esm/models/carriersenum.d.ts +3 -3
- package/esm/models/carriersenum.d.ts.map +1 -1
- package/esm/models/carriersenum.js +1 -62
- package/esm/models/carriersenum.js.map +1 -1
- package/esm/models/cod.d.ts.map +1 -1
- package/esm/models/cod.js +1 -3
- package/esm/models/cod.js.map +1 -1
- package/esm/models/confidenceresult.d.ts +23 -0
- package/esm/models/confidenceresult.d.ts.map +1 -0
- package/esm/models/confidenceresult.js +20 -0
- package/esm/models/confidenceresult.js.map +1 -0
- package/esm/models/createaddressv2op.d.ts +30 -0
- package/esm/models/createaddressv2op.d.ts.map +1 -0
- package/esm/models/createaddressv2op.js +22 -0
- package/esm/models/createaddressv2op.js.map +1 -0
- package/esm/models/customsdeclarationb13afilingoptionenum.d.ts.map +1 -1
- package/esm/models/customsdeclarationb13afilingoptionenum.js +1 -3
- package/esm/models/customsdeclarationb13afilingoptionenum.js.map +1 -1
- package/esm/models/customsdeclarationcontentstypeenum.d.ts.map +1 -1
- package/esm/models/customsdeclarationcontentstypeenum.js +1 -2
- package/esm/models/customsdeclarationcontentstypeenum.js.map +1 -1
- package/esm/models/customsdeclarationeelpfcenum.d.ts.map +1 -1
- package/esm/models/customsdeclarationeelpfcenum.js +1 -3
- package/esm/models/customsdeclarationeelpfcenum.js.map +1 -1
- package/esm/models/customsdeclarationincotermenum.d.ts.map +1 -1
- package/esm/models/customsdeclarationincotermenum.js +1 -4
- package/esm/models/customsdeclarationincotermenum.js.map +1 -1
- package/esm/models/customsdeclarationnondeliveryoptionenum.d.ts.map +1 -1
- package/esm/models/customsdeclarationnondeliveryoptionenum.js +1 -2
- package/esm/models/customsdeclarationnondeliveryoptionenum.js.map +1 -1
- package/esm/models/customstaxidentification.d.ts.map +1 -1
- package/esm/models/customstaxidentification.js +1 -2
- package/esm/models/customstaxidentification.js.map +1 -1
- package/esm/models/dangerousgoodsobject.d.ts.map +1 -1
- package/esm/models/dangerousgoodsobject.js +1 -3
- package/esm/models/dangerousgoodsobject.js.map +1 -1
- package/esm/models/defaultparceltemplate.d.ts +2 -71
- package/esm/models/defaultparceltemplate.d.ts.map +1 -1
- package/esm/models/defaultparceltemplate.js +2 -62
- package/esm/models/defaultparceltemplate.js.map +1 -1
- package/esm/models/fedexconnectexistingownaccountparameters.d.ts.map +1 -1
- package/esm/models/fedexconnectexistingownaccountparameters.js +1 -8
- package/esm/models/fedexconnectexistingownaccountparameters.js.map +1 -1
- package/esm/models/geocoordinates.d.ts +10 -0
- package/esm/models/geocoordinates.d.ts.map +1 -0
- package/esm/models/geocoordinates.js +9 -0
- package/esm/models/geocoordinates.js.map +1 -0
- package/esm/models/getorderpackingslipop.d.ts +28 -0
- package/esm/models/getorderpackingslipop.d.ts.map +1 -0
- package/esm/models/getorderpackingslipop.js +24 -0
- package/esm/models/getorderpackingslipop.js.map +1 -0
- package/esm/models/insurance.d.ts.map +1 -1
- package/esm/models/insurance.js +1 -4
- package/esm/models/insurance.js.map +1 -1
- package/esm/models/labelfiletypeenum.d.ts.map +1 -1
- package/esm/models/labelfiletypeenum.js +1 -2
- package/esm/models/labelfiletypeenum.js.map +1 -1
- package/esm/models/listordersop.d.ts.map +1 -1
- package/esm/models/listordersop.js +2 -4
- package/esm/models/listordersop.js.map +1 -1
- package/esm/models/liveratecreaterequest.d.ts.map +1 -1
- package/esm/models/liveratecreaterequest.js +2 -6
- package/esm/models/liveratecreaterequest.js.map +1 -1
- package/esm/models/location.d.ts.map +1 -1
- package/esm/models/location.js +1 -2
- package/esm/models/location.js.map +1 -1
- package/esm/models/order.d.ts +1 -29
- package/esm/models/order.d.ts.map +1 -1
- package/esm/models/order.js +1 -25
- package/esm/models/order.js.map +1 -1
- package/esm/models/ordershopappenum.d.ts.map +1 -1
- package/esm/models/ordershopappenum.js +1 -2
- package/esm/models/ordershopappenum.js.map +1 -1
- package/esm/models/orderstatusenum.d.ts.map +1 -1
- package/esm/models/orderstatusenum.js +1 -2
- package/esm/models/orderstatusenum.js.map +1 -1
- package/esm/models/parcel.d.ts +16 -2
- package/esm/models/parcel.d.ts.map +1 -1
- package/esm/models/parcel.js +10 -2
- package/esm/models/parcel.js.map +1 -1
- package/esm/models/parcelcreatefromtemplaterequest.d.ts +16 -2
- package/esm/models/parcelcreatefromtemplaterequest.d.ts.map +1 -1
- package/esm/models/parcelcreatefromtemplaterequest.js +10 -2
- package/esm/models/parcelcreatefromtemplaterequest.js.map +1 -1
- package/esm/models/parcelextra.d.ts.map +1 -1
- package/esm/models/parcelextra.js +1 -2
- package/esm/models/parcelextra.js.map +1 -1
- package/esm/models/parceltemplateenumset.d.ts.map +1 -1
- package/esm/models/parceltemplateenumset.js +6 -86
- package/esm/models/parceltemplateenumset.js.map +1 -1
- package/esm/models/parseaddressop.d.ts +20 -0
- package/esm/models/parseaddressop.d.ts.map +1 -0
- package/esm/models/parseaddressop.js +23 -0
- package/esm/models/parseaddressop.js.map +1 -0
- package/esm/models/parsedaddress.d.ts +16 -0
- package/esm/models/parsedaddress.d.ts.map +1 -0
- package/esm/models/parsedaddress.js +15 -0
- package/esm/models/parsedaddress.js.map +1 -0
- package/esm/models/recommendedaddressv2.d.ts +21 -0
- package/esm/models/recommendedaddressv2.d.ts.map +1 -0
- package/esm/models/recommendedaddressv2.js +21 -0
- package/esm/models/recommendedaddressv2.js.map +1 -0
- package/esm/models/responsemessage.d.ts.map +1 -1
- package/esm/models/responsemessage.js +1 -2
- package/esm/models/responsemessage.js.map +1 -1
- package/esm/models/servicegrouptypeenum.d.ts.map +1 -1
- package/esm/models/servicegrouptypeenum.js +1 -4
- package/esm/models/servicegrouptypeenum.js.map +1 -1
- package/esm/models/servicelevelairterraenum.d.ts.map +1 -1
- package/esm/models/servicelevelairterraenum.js +1 -5
- package/esm/models/servicelevelairterraenum.js.map +1 -1
- package/esm/models/servicelevelapcpostalenum.d.ts.map +1 -1
- package/esm/models/servicelevelapcpostalenum.js +1 -12
- package/esm/models/servicelevelapcpostalenum.js.map +1 -1
- package/esm/models/servicelevelapgenum.d.ts.map +1 -1
- package/esm/models/servicelevelapgenum.js +1 -7
- package/esm/models/servicelevelapgenum.js.map +1 -1
- package/esm/models/servicelevelaramexaustraliaenum.d.ts.map +1 -1
- package/esm/models/servicelevelaramexaustraliaenum.js +1 -8
- package/esm/models/servicelevelaramexaustraliaenum.js.map +1 -1
- package/esm/models/servicelevelasendiaenum.d.ts.map +1 -1
- package/esm/models/servicelevelasendiaenum.js +1 -11
- package/esm/models/servicelevelasendiaenum.js.map +1 -1
- package/esm/models/servicelevelaustraliapostenum.d.ts.map +1 -1
- package/esm/models/servicelevelaustraliapostenum.js +1 -13
- package/esm/models/servicelevelaustraliapostenum.js.map +1 -1
- package/esm/models/servicelevelbettertrucksenum.d.ts.map +1 -1
- package/esm/models/servicelevelbettertrucksenum.js +1 -5
- package/esm/models/servicelevelbettertrucksenum.js.map +1 -1
- package/esm/models/servicelevelcanadapostenum.d.ts.map +1 -1
- package/esm/models/servicelevelcanadapostenum.js +1 -17
- package/esm/models/servicelevelcanadapostenum.js.map +1 -1
- package/esm/models/servicelevelcdlenum.d.ts.map +1 -1
- package/esm/models/servicelevelcdlenum.js +1 -4
- package/esm/models/servicelevelcdlenum.js.map +1 -1
- package/esm/models/servicelevelchronopostenum.d.ts.map +1 -1
- package/esm/models/servicelevelchronopostenum.js +1 -9
- package/esm/models/servicelevelchronopostenum.js.map +1 -1
- package/esm/models/servicelevelcolissimoenum.d.ts.map +1 -1
- package/esm/models/servicelevelcolissimoenum.js +1 -6
- package/esm/models/servicelevelcolissimoenum.js.map +1 -1
- package/esm/models/servicelevelcorreosespanaenum.d.ts.map +1 -1
- package/esm/models/servicelevelcorreosespanaenum.js +1 -5
- package/esm/models/servicelevelcorreosespanaenum.js.map +1 -1
- package/esm/models/serviceleveldeutschepostenum.d.ts.map +1 -1
- package/esm/models/serviceleveldeutschepostenum.js +1 -13
- package/esm/models/serviceleveldeutschepostenum.js.map +1 -1
- package/esm/models/serviceleveldhlecommerceenum.d.ts.map +1 -1
- package/esm/models/serviceleveldhlecommerceenum.js +1 -31
- package/esm/models/serviceleveldhlecommerceenum.js.map +1 -1
- package/esm/models/serviceleveldhlexpressenum.d.ts.map +1 -1
- package/esm/models/serviceleveldhlexpressenum.js +1 -25
- package/esm/models/serviceleveldhlexpressenum.js.map +1 -1
- package/esm/models/serviceleveldhlgermanyenum.d.ts.map +1 -1
- package/esm/models/serviceleveldhlgermanyenum.js +1 -9
- package/esm/models/serviceleveldhlgermanyenum.js.map +1 -1
- package/esm/models/serviceleveldpddeenum.d.ts.map +1 -1
- package/esm/models/serviceleveldpddeenum.js +1 -4
- package/esm/models/serviceleveldpddeenum.js.map +1 -1
- package/esm/models/serviceleveldpdukenum.d.ts.map +1 -1
- package/esm/models/serviceleveldpdukenum.js +1 -20
- package/esm/models/serviceleveldpdukenum.js.map +1 -1
- package/esm/models/servicelevelepostglobalenum.d.ts.map +1 -1
- package/esm/models/servicelevelepostglobalenum.js +1 -16
- package/esm/models/servicelevelepostglobalenum.js.map +1 -1
- package/esm/models/servicelevelevriukenum.d.ts.map +1 -1
- package/esm/models/servicelevelevriukenum.js +1 -8
- package/esm/models/servicelevelevriukenum.js.map +1 -1
- package/esm/models/servicelevelfedexenum.d.ts.map +1 -1
- package/esm/models/servicelevelfedexenum.js +1 -27
- package/esm/models/servicelevelfedexenum.js.map +1 -1
- package/esm/models/servicelevelglobegisticsenum.d.ts.map +1 -1
- package/esm/models/servicelevelglobegisticsenum.js +1 -15
- package/esm/models/servicelevelglobegisticsenum.js.map +1 -1
- package/esm/models/servicelevelglsusenum.d.ts.map +1 -1
- package/esm/models/servicelevelglsusenum.js +1 -9
- package/esm/models/servicelevelglsusenum.js.map +1 -1
- package/esm/models/serviceleveljitsuenum.d.ts.map +1 -1
- package/esm/models/serviceleveljitsuenum.js +1 -5
- package/esm/models/serviceleveljitsuenum.js.map +1 -1
- package/esm/models/servicelevellasershipenum.d.ts.map +1 -1
- package/esm/models/servicelevellasershipenum.js +1 -4
- package/esm/models/servicelevellasershipenum.js.map +1 -1
- package/esm/models/servicelevellsoenum.d.ts.map +1 -1
- package/esm/models/servicelevellsoenum.js +1 -9
- package/esm/models/servicelevellsoenum.js.map +1 -1
- package/esm/models/servicelevelmondialrelayenum.d.ts.map +1 -1
- package/esm/models/servicelevelmondialrelayenum.js +1 -4
- package/esm/models/servicelevelmondialrelayenum.js.map +1 -1
- package/esm/models/servicelevelontracenum.d.ts.map +1 -1
- package/esm/models/servicelevelontracenum.js +1 -6
- package/esm/models/servicelevelontracenum.js.map +1 -1
- package/esm/models/servicelevelparcelforceenum.d.ts.map +1 -1
- package/esm/models/servicelevelparcelforceenum.js +1 -6
- package/esm/models/servicelevelparcelforceenum.js.map +1 -1
- package/esm/models/servicelevelpostitalianeenum.d.ts.map +1 -1
- package/esm/models/servicelevelpostitalianeenum.js +1 -4
- package/esm/models/servicelevelpostitalianeenum.js.map +1 -1
- package/esm/models/servicelevelpurolatorenum.d.ts.map +1 -1
- package/esm/models/servicelevelpurolatorenum.js +1 -21
- package/esm/models/servicelevelpurolatorenum.js.map +1 -1
- package/esm/models/servicelevelroyalmailenum.d.ts.map +1 -1
- package/esm/models/servicelevelroyalmailenum.js +1 -23
- package/esm/models/servicelevelroyalmailenum.js.map +1 -1
- package/esm/models/servicelevelsendleenum.d.ts.map +1 -1
- package/esm/models/servicelevelsendleenum.js +1 -5
- package/esm/models/servicelevelsendleenum.js.map +1 -1
- package/esm/models/servicelevelswyftenum.d.ts.map +1 -1
- package/esm/models/servicelevelswyftenum.js +1 -5
- package/esm/models/servicelevelswyftenum.js.map +1 -1
- package/esm/models/serviceleveludsenum.d.ts.map +1 -1
- package/esm/models/serviceleveludsenum.js +1 -4
- package/esm/models/serviceleveludsenum.js.map +1 -1
- package/esm/models/servicelevelupsenum.d.ts.map +1 -1
- package/esm/models/servicelevelupsenum.js +1 -28
- package/esm/models/servicelevelupsenum.js.map +1 -1
- package/esm/models/serviceleveluspsenum.d.ts.map +1 -1
- package/esm/models/serviceleveluspsenum.js +1 -10
- package/esm/models/serviceleveluspsenum.js.map +1 -1
- package/esm/models/servicelevelvehoenum.d.ts.map +1 -1
- package/esm/models/servicelevelvehoenum.js +1 -5
- package/esm/models/servicelevelvehoenum.js.map +1 -1
- package/esm/models/servicelevelwithparent.d.ts.map +1 -1
- package/esm/models/servicelevelwithparent.js +1 -4
- package/esm/models/servicelevelwithparent.js.map +1 -1
- package/esm/models/shipment.d.ts.map +1 -1
- package/esm/models/shipment.js +1 -4
- package/esm/models/shipment.js.map +1 -1
- package/esm/models/shipmentextra.d.ts.map +1 -1
- package/esm/models/shipmentextra.js +1 -2
- package/esm/models/shipmentextra.js.map +1 -1
- package/esm/models/transaction.d.ts.map +1 -1
- package/esm/models/transaction.js +2 -8
- package/esm/models/transaction.js.map +1 -1
- package/esm/models/upsconnectexistingownaccountparameters.d.ts.map +1 -1
- package/esm/models/upsconnectexistingownaccountparameters.js +1 -10
- package/esm/models/upsconnectexistingownaccountparameters.js.map +1 -1
- package/esm/models/userparceltemplate.d.ts +5 -57
- package/esm/models/userparceltemplate.d.ts.map +1 -1
- package/esm/models/userparceltemplate.js +5 -49
- package/esm/models/userparceltemplate.js.map +1 -1
- package/esm/models/userparceltemplateupdaterequest.d.ts +4 -45
- package/esm/models/userparceltemplateupdaterequest.d.ts.map +1 -1
- package/esm/models/userparceltemplateupdaterequest.js +4 -38
- package/esm/models/userparceltemplateupdaterequest.js.map +1 -1
- package/esm/models/userparceltemplatewithoutcarriertemplatecreaterequest.d.ts +4 -45
- package/esm/models/userparceltemplatewithoutcarriertemplatecreaterequest.d.ts.map +1 -1
- package/esm/models/userparceltemplatewithoutcarriertemplatecreaterequest.js +4 -38
- package/esm/models/userparceltemplatewithoutcarriertemplatecreaterequest.js.map +1 -1
- package/esm/models/validateaddressv2op.d.ts +265 -0
- package/esm/models/validateaddressv2op.d.ts.map +1 -0
- package/esm/models/validateaddressv2op.js +258 -0
- package/esm/models/validateaddressv2op.js.map +1 -0
- package/esm/models/validationresultv2.d.ts +15 -0
- package/esm/models/validationresultv2.d.ts.map +1 -0
- package/esm/models/validationresultv2.js +14 -0
- package/esm/models/validationresultv2.js.map +1 -0
- package/manifest.json +21 -5
- package/package.json +1 -1
- package/src/funcs/{addressesCreate.ts → addressesCreateV1.ts} +1 -1
- package/src/funcs/addressesCreateV2.ts +178 -0
- package/src/funcs/addressesParse.ts +178 -0
- package/src/funcs/addressesValidateV2.ts +188 -0
- package/src/funcs/ordersGetPackingSlip.ts +176 -0
- package/src/lib/config.ts +3 -3
- package/src/mcp-server/mcp-server.ts +1 -1
- package/src/mcp-server/server.ts +11 -3
- package/src/mcp-server/tools/addressesCreateV1.ts +58 -0
- package/src/mcp-server/tools/addressesCreateV2.ts +92 -0
- package/src/mcp-server/tools/addressesParse.ts +76 -0
- package/src/mcp-server/tools/addressesValidate.ts +12 -3
- package/src/mcp-server/tools/addressesValidateV2.ts +105 -0
- package/src/mcp-server/tools/ordersGetPackingSlip.ts +76 -0
- package/src/mcp-server/tools/ordersList.ts +20 -2
- package/src/models/addressanalysisv2.ts +41 -0
- package/src/models/addresscreaterequestv2.ts +64 -0
- package/src/models/addressdatav2.ts +56 -0
- package/src/models/addressv2.ts +34 -0
- package/src/models/addressvalidationresults.ts +1 -2
- package/src/models/addressvalidationresultv2.ts +34 -0
- package/src/models/addresswithmetadataresponse.ts +25 -0
- package/src/models/batch.ts +1 -5
- package/src/models/batchshipment.ts +1 -4
- package/src/models/batchshipmentpaginatedlist.ts +1 -2
- package/src/models/carriersenum.ts +1 -62
- package/src/models/cod.ts +1 -3
- package/src/models/confidenceresult.ts +36 -0
- package/src/models/createaddressv2op.ts +73 -0
- package/src/models/customsdeclarationb13afilingoptionenum.ts +1 -3
- package/src/models/customsdeclarationcontentstypeenum.ts +1 -2
- package/src/models/customsdeclarationeelpfcenum.ts +1 -3
- package/src/models/customsdeclarationincotermenum.ts +1 -4
- package/src/models/customsdeclarationnondeliveryoptionenum.ts +1 -2
- package/src/models/customstaxidentification.ts +1 -2
- package/src/models/dangerousgoodsobject.ts +1 -3
- package/src/models/defaultparceltemplate.ts +5 -122
- package/src/models/fedexconnectexistingownaccountparameters.ts +1 -8
- package/src/models/geocoordinates.ts +18 -0
- package/src/models/getorderpackingslipop.ts +61 -0
- package/src/models/insurance.ts +1 -4
- package/src/models/labelfiletypeenum.ts +1 -2
- package/src/models/listordersop.ts +2 -4
- package/src/models/liveratecreaterequest.ts +2 -6
- package/src/models/location.ts +1 -2
- package/src/models/order.ts +2 -61
- package/src/models/ordershopappenum.ts +1 -2
- package/src/models/orderstatusenum.ts +1 -2
- package/src/models/parcel.ts +30 -3
- package/src/models/parcelcreatefromtemplaterequest.ts +32 -3
- package/src/models/parceltemplateenumset.ts +6 -86
- package/src/models/parseaddressop.ts +42 -0
- package/src/models/parsedaddress.ts +32 -0
- package/src/models/recommendedaddressv2.ts +43 -0
- package/src/models/responsemessage.ts +1 -2
- package/src/models/servicegrouptypeenum.ts +1 -4
- package/src/models/servicelevelairterraenum.ts +1 -5
- package/src/models/servicelevelapcpostalenum.ts +1 -12
- package/src/models/servicelevelapgenum.ts +1 -7
- package/src/models/servicelevelaramexaustraliaenum.ts +1 -8
- package/src/models/servicelevelasendiaenum.ts +1 -11
- package/src/models/servicelevelaustraliapostenum.ts +1 -13
- package/src/models/servicelevelbettertrucksenum.ts +1 -5
- package/src/models/servicelevelcanadapostenum.ts +1 -17
- package/src/models/servicelevelcdlenum.ts +1 -4
- package/src/models/servicelevelchronopostenum.ts +1 -9
- package/src/models/servicelevelcolissimoenum.ts +1 -6
- package/src/models/servicelevelcorreosespanaenum.ts +1 -5
- package/src/models/serviceleveldeutschepostenum.ts +1 -13
- package/src/models/serviceleveldhlecommerceenum.ts +1 -31
- package/src/models/serviceleveldhlexpressenum.ts +1 -25
- package/src/models/serviceleveldhlgermanyenum.ts +1 -9
- package/src/models/serviceleveldpddeenum.ts +1 -4
- package/src/models/serviceleveldpdukenum.ts +1 -20
- package/src/models/servicelevelepostglobalenum.ts +1 -16
- package/src/models/servicelevelevriukenum.ts +1 -8
- package/src/models/servicelevelfedexenum.ts +1 -27
- package/src/models/servicelevelglobegisticsenum.ts +1 -15
- package/src/models/servicelevelglsusenum.ts +1 -9
- package/src/models/serviceleveljitsuenum.ts +1 -5
- package/src/models/servicelevellasershipenum.ts +1 -4
- package/src/models/servicelevellsoenum.ts +1 -9
- package/src/models/servicelevelmondialrelayenum.ts +1 -4
- package/src/models/servicelevelontracenum.ts +1 -6
- package/src/models/servicelevelparcelforceenum.ts +1 -6
- package/src/models/servicelevelpostitalianeenum.ts +1 -4
- package/src/models/servicelevelpurolatorenum.ts +1 -21
- package/src/models/servicelevelroyalmailenum.ts +1 -23
- package/src/models/servicelevelsendleenum.ts +1 -5
- package/src/models/servicelevelswyftenum.ts +1 -5
- package/src/models/serviceleveludsenum.ts +1 -4
- package/src/models/servicelevelupsenum.ts +1 -28
- package/src/models/serviceleveluspsenum.ts +1 -10
- package/src/models/servicelevelvehoenum.ts +1 -5
- package/src/models/servicelevelwithparent.ts +1 -4
- package/src/models/shipment.ts +1 -4
- package/src/models/shipmentextra.ts +1 -2
- package/src/models/transaction.ts +2 -8
- package/src/models/upsconnectexistingownaccountparameters.ts +1 -10
- package/src/models/userparceltemplate.ts +11 -90
- package/src/models/userparceltemplateupdaterequest.ts +9 -62
- package/src/models/userparceltemplatewithoutcarriertemplatecreaterequest.ts +9 -70
- package/src/models/validateaddressv2op.ts +319 -0
- package/src/models/validationresultv2.ts +29 -0
- package/src/mcp-server/tools/addressesCreate.ts +0 -74
- package/src/models/parcelextra.ts +0 -33
|
@@ -0,0 +1,176 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* Code generated by Speakeasy (https://speakeasy.com). DO NOT EDIT.
|
|
3
|
+
*/
|
|
4
|
+
|
|
5
|
+
import { ShippoSDKCore } from "../core.js";
|
|
6
|
+
import { encodeSimple } from "../lib/encodings.js";
|
|
7
|
+
import * as M from "../lib/matchers.js";
|
|
8
|
+
import { compactMap } from "../lib/primitives.js";
|
|
9
|
+
import { safeParse } from "../lib/schemas.js";
|
|
10
|
+
import { RequestOptions } from "../lib/sdks.js";
|
|
11
|
+
import { extractSecurity, resolveGlobalSecurity } from "../lib/security.js";
|
|
12
|
+
import { pathToFunc } from "../lib/url.js";
|
|
13
|
+
import { APIError } from "../models/errors/apierror.js";
|
|
14
|
+
import {
|
|
15
|
+
ConnectionError,
|
|
16
|
+
InvalidRequestError,
|
|
17
|
+
RequestAbortedError,
|
|
18
|
+
RequestTimeoutError,
|
|
19
|
+
UnexpectedClientError,
|
|
20
|
+
} from "../models/errors/httpclienterrors.js";
|
|
21
|
+
import { SDKValidationError } from "../models/errors/sdkvalidationerror.js";
|
|
22
|
+
import {
|
|
23
|
+
GetOrderPackingSlipRequest,
|
|
24
|
+
GetOrderPackingSlipRequest$zodSchema,
|
|
25
|
+
GetOrderPackingSlipResponse,
|
|
26
|
+
GetOrderPackingSlipResponse$zodSchema,
|
|
27
|
+
} from "../models/getorderpackingslipop.js";
|
|
28
|
+
import { APICall, APIPromise } from "../types/async.js";
|
|
29
|
+
import { Result } from "../types/fp.js";
|
|
30
|
+
|
|
31
|
+
/**
|
|
32
|
+
* Generate a packing slip for an order
|
|
33
|
+
*
|
|
34
|
+
* @remarks
|
|
35
|
+
* Generates a packing slip PDF for the specified order. Returns a signed URL to download the PDF. The URL expires after 24 hours.
|
|
36
|
+
*/
|
|
37
|
+
export function ordersGetPackingSlip(
|
|
38
|
+
client$: ShippoSDKCore,
|
|
39
|
+
request: GetOrderPackingSlipRequest,
|
|
40
|
+
options?: RequestOptions,
|
|
41
|
+
): APIPromise<
|
|
42
|
+
Result<
|
|
43
|
+
GetOrderPackingSlipResponse,
|
|
44
|
+
| APIError
|
|
45
|
+
| SDKValidationError
|
|
46
|
+
| UnexpectedClientError
|
|
47
|
+
| InvalidRequestError
|
|
48
|
+
| RequestAbortedError
|
|
49
|
+
| RequestTimeoutError
|
|
50
|
+
| ConnectionError
|
|
51
|
+
>
|
|
52
|
+
> {
|
|
53
|
+
return new APIPromise($do(
|
|
54
|
+
client$,
|
|
55
|
+
request,
|
|
56
|
+
options,
|
|
57
|
+
));
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
async function $do(
|
|
61
|
+
client$: ShippoSDKCore,
|
|
62
|
+
request: GetOrderPackingSlipRequest,
|
|
63
|
+
options?: RequestOptions,
|
|
64
|
+
): Promise<
|
|
65
|
+
[
|
|
66
|
+
Result<
|
|
67
|
+
GetOrderPackingSlipResponse,
|
|
68
|
+
| APIError
|
|
69
|
+
| SDKValidationError
|
|
70
|
+
| UnexpectedClientError
|
|
71
|
+
| InvalidRequestError
|
|
72
|
+
| RequestAbortedError
|
|
73
|
+
| RequestTimeoutError
|
|
74
|
+
| ConnectionError
|
|
75
|
+
>,
|
|
76
|
+
APICall,
|
|
77
|
+
]
|
|
78
|
+
> {
|
|
79
|
+
const parsed$ = safeParse(
|
|
80
|
+
request,
|
|
81
|
+
(value$) => GetOrderPackingSlipRequest$zodSchema.parse(value$),
|
|
82
|
+
"Input validation failed",
|
|
83
|
+
);
|
|
84
|
+
if (!parsed$.ok) {
|
|
85
|
+
return [parsed$, { status: "invalid" }];
|
|
86
|
+
}
|
|
87
|
+
const payload$ = parsed$.value;
|
|
88
|
+
const body$ = null;
|
|
89
|
+
|
|
90
|
+
const pathParams$ = {
|
|
91
|
+
OrderId: encodeSimple("OrderId", payload$.OrderId, {
|
|
92
|
+
explode: false,
|
|
93
|
+
charEncoding: "percent",
|
|
94
|
+
}),
|
|
95
|
+
};
|
|
96
|
+
const path$ = pathToFunc("/orders/{OrderId}/packingslip/")(
|
|
97
|
+
pathParams$,
|
|
98
|
+
);
|
|
99
|
+
|
|
100
|
+
const headers$ = new Headers(compactMap({
|
|
101
|
+
Accept: "application/json",
|
|
102
|
+
"SHIPPO-API-VERSION": encodeSimple(
|
|
103
|
+
"SHIPPO-API-VERSION",
|
|
104
|
+
client$._options.shippoApiVersion,
|
|
105
|
+
{ explode: false, charEncoding: "none" },
|
|
106
|
+
),
|
|
107
|
+
}));
|
|
108
|
+
const securityInput = await extractSecurity(client$._options.security);
|
|
109
|
+
const requestSecurity = resolveGlobalSecurity(securityInput);
|
|
110
|
+
|
|
111
|
+
const context = {
|
|
112
|
+
options: client$._options,
|
|
113
|
+
baseURL: options?.serverURL ?? client$._baseURL ?? "",
|
|
114
|
+
operationID: "GetOrderPackingSlip",
|
|
115
|
+
oAuth2Scopes: null,
|
|
116
|
+
resolvedSecurity: requestSecurity,
|
|
117
|
+
securitySource: client$._options.security,
|
|
118
|
+
retryConfig: options?.retries
|
|
119
|
+
|| client$._options.retryConfig
|
|
120
|
+
|| { strategy: "none" },
|
|
121
|
+
retryCodes: options?.retryCodes || [
|
|
122
|
+
"429",
|
|
123
|
+
"500",
|
|
124
|
+
"502",
|
|
125
|
+
"503",
|
|
126
|
+
"504",
|
|
127
|
+
],
|
|
128
|
+
};
|
|
129
|
+
|
|
130
|
+
const requestRes = client$._createRequest(context, {
|
|
131
|
+
security: requestSecurity,
|
|
132
|
+
method: "GET",
|
|
133
|
+
baseURL: options?.serverURL,
|
|
134
|
+
path: path$,
|
|
135
|
+
headers: headers$,
|
|
136
|
+
body: body$,
|
|
137
|
+
userAgent: client$._options.userAgent,
|
|
138
|
+
timeoutMs: options?.timeoutMs || client$._options.timeoutMs
|
|
139
|
+
|| -1,
|
|
140
|
+
}, options);
|
|
141
|
+
if (!requestRes.ok) {
|
|
142
|
+
return [requestRes, { status: "invalid" }];
|
|
143
|
+
}
|
|
144
|
+
const req$ = requestRes.value;
|
|
145
|
+
|
|
146
|
+
const doResult = await client$._do(req$, {
|
|
147
|
+
context,
|
|
148
|
+
errorCodes: [],
|
|
149
|
+
retryConfig: context.retryConfig,
|
|
150
|
+
retryCodes: context.retryCodes,
|
|
151
|
+
});
|
|
152
|
+
if (!doResult.ok) {
|
|
153
|
+
return [doResult, { status: "request-error", request: req$ }];
|
|
154
|
+
}
|
|
155
|
+
const response = doResult.value;
|
|
156
|
+
const responseFields$ = {
|
|
157
|
+
HttpMeta: { Response: response, Request: req$ },
|
|
158
|
+
};
|
|
159
|
+
|
|
160
|
+
const [result$] = await M.match<
|
|
161
|
+
GetOrderPackingSlipResponse,
|
|
162
|
+
| APIError
|
|
163
|
+
| SDKValidationError
|
|
164
|
+
| UnexpectedClientError
|
|
165
|
+
| InvalidRequestError
|
|
166
|
+
| RequestAbortedError
|
|
167
|
+
| RequestTimeoutError
|
|
168
|
+
| ConnectionError
|
|
169
|
+
>(
|
|
170
|
+
M.json(200, GetOrderPackingSlipResponse$zodSchema, { key: "object" }),
|
|
171
|
+
M.json(400, GetOrderPackingSlipResponse$zodSchema, { key: "BadRequest" }),
|
|
172
|
+
M.nil(404, GetOrderPackingSlipResponse$zodSchema),
|
|
173
|
+
)(response, req$, { extraFields: responseFields$ });
|
|
174
|
+
|
|
175
|
+
return [result$, { status: "complete", request: req$, response }];
|
|
176
|
+
}
|
package/src/lib/config.ts
CHANGED
|
@@ -67,8 +67,8 @@ export function serverURLFromOptions(options: SDKOptions): URL | null {
|
|
|
67
67
|
export const SDK_METADATA = {
|
|
68
68
|
language: "typescript",
|
|
69
69
|
openapiDocVersion: "2018-02-08",
|
|
70
|
-
sdkVersion: "2.0.
|
|
71
|
-
genVersion: "2.
|
|
70
|
+
sdkVersion: "2.0.18",
|
|
71
|
+
genVersion: "2.791.1",
|
|
72
72
|
userAgent:
|
|
73
|
-
"speakeasy-sdk/mcp-typescript 2.0.
|
|
73
|
+
"speakeasy-sdk/mcp-typescript 2.0.18 2.791.1 2018-02-08 @shippo/shippo-mcp",
|
|
74
74
|
} as const;
|
package/src/mcp-server/server.ts
CHANGED
|
@@ -13,10 +13,13 @@ import {
|
|
|
13
13
|
} from "./resources.js";
|
|
14
14
|
import { MCPScope } from "./scopes.js";
|
|
15
15
|
import { createRegisterTool } from "./tools.js";
|
|
16
|
-
import { tool$
|
|
16
|
+
import { tool$addressesCreateV1 } from "./tools/addressesCreateV1.js";
|
|
17
|
+
import { tool$addressesCreateV2 } from "./tools/addressesCreateV2.js";
|
|
17
18
|
import { tool$addressesGet } from "./tools/addressesGet.js";
|
|
18
19
|
import { tool$addressesList } from "./tools/addressesList.js";
|
|
20
|
+
import { tool$addressesParse } from "./tools/addressesParse.js";
|
|
19
21
|
import { tool$addressesValidate } from "./tools/addressesValidate.js";
|
|
22
|
+
import { tool$addressesValidateV2 } from "./tools/addressesValidateV2.js";
|
|
20
23
|
import { tool$batchesAddShipments } from "./tools/batchesAddShipments.js";
|
|
21
24
|
import { tool$batchesCreate } from "./tools/batchesCreate.js";
|
|
22
25
|
import { tool$batchesGet } from "./tools/batchesGet.js";
|
|
@@ -42,6 +45,7 @@ import { tool$manifestsGet } from "./tools/manifestsGet.js";
|
|
|
42
45
|
import { tool$manifestsList } from "./tools/manifestsList.js";
|
|
43
46
|
import { tool$ordersCreate } from "./tools/ordersCreate.js";
|
|
44
47
|
import { tool$ordersGet } from "./tools/ordersGet.js";
|
|
48
|
+
import { tool$ordersGetPackingSlip } from "./tools/ordersGetPackingSlip.js";
|
|
45
49
|
import { tool$ordersList } from "./tools/ordersList.js";
|
|
46
50
|
import { tool$parcelsCreate } from "./tools/parcelsCreate.js";
|
|
47
51
|
import { tool$parcelsGet } from "./tools/parcelsGet.js";
|
|
@@ -96,7 +100,7 @@ export function createMCPServer(deps: {
|
|
|
96
100
|
}) {
|
|
97
101
|
const server = new McpServer({
|
|
98
102
|
name: "ShippoSDK",
|
|
99
|
-
version: "2.0.
|
|
103
|
+
version: "2.0.18",
|
|
100
104
|
});
|
|
101
105
|
|
|
102
106
|
const getClient = deps.getSDK || (() =>
|
|
@@ -141,9 +145,12 @@ export function createMCPServer(deps: {
|
|
|
141
145
|
void register; // suppress unused warnings
|
|
142
146
|
|
|
143
147
|
tool(tool$addressesList);
|
|
144
|
-
tool(tool$
|
|
148
|
+
tool(tool$addressesCreateV1);
|
|
145
149
|
tool(tool$addressesGet);
|
|
146
150
|
tool(tool$addressesValidate);
|
|
151
|
+
tool(tool$addressesParse);
|
|
152
|
+
tool(tool$addressesValidateV2);
|
|
153
|
+
tool(tool$addressesCreateV2);
|
|
147
154
|
tool(tool$batchesCreate);
|
|
148
155
|
tool(tool$batchesGet);
|
|
149
156
|
tool(tool$batchesAddShipments);
|
|
@@ -172,6 +179,7 @@ export function createMCPServer(deps: {
|
|
|
172
179
|
tool(tool$ordersList);
|
|
173
180
|
tool(tool$ordersCreate);
|
|
174
181
|
tool(tool$ordersGet);
|
|
182
|
+
tool(tool$ordersGetPackingSlip);
|
|
175
183
|
tool(tool$carrierParcelTemplatesList);
|
|
176
184
|
tool(tool$carrierParcelTemplatesGet);
|
|
177
185
|
tool(tool$parcelsList);
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* Code generated by Speakeasy (https://speakeasy.com). DO NOT EDIT.
|
|
3
|
+
*/
|
|
4
|
+
|
|
5
|
+
import { addressesCreateV1 } from "../../funcs/addressesCreateV1.js";
|
|
6
|
+
import { AddressCreateRequest$zodSchema } from "../../models/addresscreaterequest.js";
|
|
7
|
+
import { formatResult, ToolDefinition } from "../tools.js";
|
|
8
|
+
|
|
9
|
+
const args = {
|
|
10
|
+
request: AddressCreateRequest$zodSchema,
|
|
11
|
+
};
|
|
12
|
+
|
|
13
|
+
export const tool$addressesCreateV1: ToolDefinition<typeof args> = {
|
|
14
|
+
name: "addresses-create-v1",
|
|
15
|
+
description:
|
|
16
|
+
`**DEPRECATED - Use \`addresses-create-v2\` instead for cleaner API format.**
|
|
17
|
+
|
|
18
|
+
This is the legacy v1 address creation endpoint. It uses different field names
|
|
19
|
+
(street1, city, state, zip) compared to the newer v2 format.
|
|
20
|
+
|
|
21
|
+
**Prefer \`addresses-create-v2\`** which uses standardized field names:
|
|
22
|
+
- \`address_line_1\` instead of \`street1\`
|
|
23
|
+
- \`city_locality\` instead of \`city\`
|
|
24
|
+
- \`state_province\` instead of \`state\`
|
|
25
|
+
- \`postal_code\` instead of \`zip\`
|
|
26
|
+
|
|
27
|
+
**For address validation, use \`addresses-validate-v2\`.**
|
|
28
|
+
|
|
29
|
+
Only use this tool if you specifically need v1 API compatibility.
|
|
30
|
+
`,
|
|
31
|
+
scopes: ["write"],
|
|
32
|
+
annotations: {
|
|
33
|
+
"title": "",
|
|
34
|
+
"destructiveHint": false,
|
|
35
|
+
"idempotentHint": false,
|
|
36
|
+
"openWorldHint": false,
|
|
37
|
+
"readOnlyHint": false,
|
|
38
|
+
},
|
|
39
|
+
args,
|
|
40
|
+
tool: async (client, args, ctx) => {
|
|
41
|
+
const [result, apiCall] = await addressesCreateV1(
|
|
42
|
+
client,
|
|
43
|
+
args.request,
|
|
44
|
+
{ fetchOptions: { signal: ctx.signal } },
|
|
45
|
+
).$inspect();
|
|
46
|
+
|
|
47
|
+
if (!result.ok) {
|
|
48
|
+
return {
|
|
49
|
+
content: [{ type: "text", text: result.error.message }],
|
|
50
|
+
isError: true,
|
|
51
|
+
};
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
const value = result.value;
|
|
55
|
+
|
|
56
|
+
return formatResult(value, apiCall);
|
|
57
|
+
},
|
|
58
|
+
};
|
|
@@ -0,0 +1,92 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* Code generated by Speakeasy (https://speakeasy.com). DO NOT EDIT.
|
|
3
|
+
*/
|
|
4
|
+
|
|
5
|
+
import { addressesCreateV2 } from "../../funcs/addressesCreateV2.js";
|
|
6
|
+
import { AddressCreateRequestV2$zodSchema } from "../../models/addresscreaterequestv2.js";
|
|
7
|
+
import { formatResult, ToolDefinition } from "../tools.js";
|
|
8
|
+
|
|
9
|
+
const args = {
|
|
10
|
+
request: AddressCreateRequestV2$zodSchema,
|
|
11
|
+
};
|
|
12
|
+
|
|
13
|
+
export const tool$addressesCreateV2: ToolDefinition<typeof args> = {
|
|
14
|
+
name: "addresses-create-v2",
|
|
15
|
+
description:
|
|
16
|
+
`**PRIMARY ADDRESS CREATION TOOL** - Use this tool to create and save address records.
|
|
17
|
+
|
|
18
|
+
This is the recommended v2 endpoint for creating addresses with a cleaner, standardized format.
|
|
19
|
+
|
|
20
|
+
**Required Fields:**
|
|
21
|
+
- \`name\`: The addressee's name (max 64 chars)
|
|
22
|
+
- \`address_line_1\`: Street address (1-100 chars)
|
|
23
|
+
- \`country_code\`: ISO 3166 country code (2 chars, e.g., "US")
|
|
24
|
+
|
|
25
|
+
**Optional Fields:**
|
|
26
|
+
- \`organization\`: Company/organization name
|
|
27
|
+
- \`email\`: Email address
|
|
28
|
+
- \`phone\`: Phone number
|
|
29
|
+
- \`address_line_2\`: Apt, suite, unit, etc.
|
|
30
|
+
- \`city_locality\`: City name
|
|
31
|
+
- \`state_province\`: State/province abbreviation
|
|
32
|
+
- \`postal_code\`: ZIP/postal code
|
|
33
|
+
- \`address_type\`: unknown, residential, commercial, po_box, military
|
|
34
|
+
|
|
35
|
+
**Example Request:**
|
|
36
|
+
\`\`\`json
|
|
37
|
+
{
|
|
38
|
+
"name": "Wilson",
|
|
39
|
+
"organization": "Shippo",
|
|
40
|
+
"email": "user@shippo.com",
|
|
41
|
+
"phone": "+1-4155550132",
|
|
42
|
+
"address_line_1": "731 Market Street",
|
|
43
|
+
"address_line_2": "#200",
|
|
44
|
+
"city_locality": "San Francisco",
|
|
45
|
+
"state_province": "CA",
|
|
46
|
+
"postal_code": "94103",
|
|
47
|
+
"country_code": "US",
|
|
48
|
+
"address_type": "commercial"
|
|
49
|
+
}
|
|
50
|
+
\`\`\`
|
|
51
|
+
|
|
52
|
+
**Response includes:**
|
|
53
|
+
- \`id\`: Unique address identifier for future reference
|
|
54
|
+
- \`address\`: The saved address data
|
|
55
|
+
- \`created_at\`/\`updated_at\`: Timestamps
|
|
56
|
+
|
|
57
|
+
**Use Cases:**
|
|
58
|
+
- Save addresses for reuse in shipments
|
|
59
|
+
- Build an address book
|
|
60
|
+
- Store customer shipping addresses
|
|
61
|
+
|
|
62
|
+
**For address validation, use \`addresses-validate-v2\`** which provides
|
|
63
|
+
confidence scores, geo coordinates, and recommended corrections.
|
|
64
|
+
`,
|
|
65
|
+
scopes: ["write"],
|
|
66
|
+
annotations: {
|
|
67
|
+
"title": "",
|
|
68
|
+
"destructiveHint": false,
|
|
69
|
+
"idempotentHint": false,
|
|
70
|
+
"openWorldHint": false,
|
|
71
|
+
"readOnlyHint": false,
|
|
72
|
+
},
|
|
73
|
+
args,
|
|
74
|
+
tool: async (client, args, ctx) => {
|
|
75
|
+
const [result, apiCall] = await addressesCreateV2(
|
|
76
|
+
client,
|
|
77
|
+
args.request,
|
|
78
|
+
{ fetchOptions: { signal: ctx.signal } },
|
|
79
|
+
).$inspect();
|
|
80
|
+
|
|
81
|
+
if (!result.ok) {
|
|
82
|
+
return {
|
|
83
|
+
content: [{ type: "text", text: result.error.message }],
|
|
84
|
+
isError: true,
|
|
85
|
+
};
|
|
86
|
+
}
|
|
87
|
+
|
|
88
|
+
const value = result.value;
|
|
89
|
+
|
|
90
|
+
return formatResult(value, apiCall);
|
|
91
|
+
},
|
|
92
|
+
};
|
|
@@ -0,0 +1,76 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* Code generated by Speakeasy (https://speakeasy.com). DO NOT EDIT.
|
|
3
|
+
*/
|
|
4
|
+
|
|
5
|
+
import { addressesParse } from "../../funcs/addressesParse.js";
|
|
6
|
+
import { ParseAddressRequest$zodSchema } from "../../models/parseaddressop.js";
|
|
7
|
+
import { formatResult, ToolDefinition } from "../tools.js";
|
|
8
|
+
|
|
9
|
+
const args = {
|
|
10
|
+
request: ParseAddressRequest$zodSchema,
|
|
11
|
+
};
|
|
12
|
+
|
|
13
|
+
export const tool$addressesParse: ToolDefinition<typeof args> = {
|
|
14
|
+
name: "addresses-parse",
|
|
15
|
+
description:
|
|
16
|
+
`**ADDRESS PARSER** - Converts an unstructured address string into a structured address object.
|
|
17
|
+
|
|
18
|
+
Use this tool when you have a single address string (like from customer input, emails,
|
|
19
|
+
or CSV imports) and need to parse it into structured components.
|
|
20
|
+
|
|
21
|
+
**Input Format Tips:**
|
|
22
|
+
- Use commas (,) as delimiters between address parts
|
|
23
|
+
- Follow this order: street address, city, state, postal code, country
|
|
24
|
+
- Phone and email can be anywhere in the string
|
|
25
|
+
|
|
26
|
+
**Example Input:**
|
|
27
|
+
"Shippo 731 Market St #200, San Francisco, CA 94103 US shippo@shippo.com +1-555-999-8888"
|
|
28
|
+
|
|
29
|
+
**Example Output:**
|
|
30
|
+
\`\`\`json
|
|
31
|
+
{
|
|
32
|
+
"address_line_1": "731 MARKET ST",
|
|
33
|
+
"address_line_2": "#200",
|
|
34
|
+
"city_locality": "SAN FRANCISCO",
|
|
35
|
+
"state_province": "CA",
|
|
36
|
+
"postal_code": "94103",
|
|
37
|
+
"country_code": "US",
|
|
38
|
+
"email": "shippo@shippo.com",
|
|
39
|
+
"phone": "+1-555-999-8888"
|
|
40
|
+
}
|
|
41
|
+
\`\`\`
|
|
42
|
+
|
|
43
|
+
**Use Cases:**
|
|
44
|
+
- Parse addresses from customer contact forms
|
|
45
|
+
- Extract structured data from email signatures
|
|
46
|
+
- Process bulk address imports
|
|
47
|
+
- Clean up poorly formatted address data
|
|
48
|
+
`,
|
|
49
|
+
scopes: ["read"],
|
|
50
|
+
annotations: {
|
|
51
|
+
"title": "",
|
|
52
|
+
"destructiveHint": false,
|
|
53
|
+
"idempotentHint": false,
|
|
54
|
+
"openWorldHint": false,
|
|
55
|
+
"readOnlyHint": false,
|
|
56
|
+
},
|
|
57
|
+
args,
|
|
58
|
+
tool: async (client, args, ctx) => {
|
|
59
|
+
const [result, apiCall] = await addressesParse(
|
|
60
|
+
client,
|
|
61
|
+
args.request,
|
|
62
|
+
{ fetchOptions: { signal: ctx.signal } },
|
|
63
|
+
).$inspect();
|
|
64
|
+
|
|
65
|
+
if (!result.ok) {
|
|
66
|
+
return {
|
|
67
|
+
content: [{ type: "text", text: result.error.message }],
|
|
68
|
+
isError: true,
|
|
69
|
+
};
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
const value = result.value;
|
|
73
|
+
|
|
74
|
+
return formatResult(value, apiCall);
|
|
75
|
+
},
|
|
76
|
+
};
|
|
@@ -13,10 +13,19 @@ const args = {
|
|
|
13
13
|
export const tool$addressesValidate: ToolDefinition<typeof args> = {
|
|
14
14
|
name: "addresses-validate-existing",
|
|
15
15
|
description:
|
|
16
|
-
`**
|
|
16
|
+
`**DEPRECATED - Use \`addresses-validate-v2\` instead for better validation results.**
|
|
17
17
|
|
|
18
|
-
|
|
19
|
-
|
|
18
|
+
This v1 endpoint validates an already created address using its ID.
|
|
19
|
+
It only works on addresses that have been saved to Shippo's address book.
|
|
20
|
+
|
|
21
|
+
**Prefer \`addresses-validate-v2\`** which:
|
|
22
|
+
- Validates any address (no need to create first)
|
|
23
|
+
- Returns confidence scores (high/medium/low)
|
|
24
|
+
- Provides recommended address corrections
|
|
25
|
+
- Returns geo coordinates (latitude/longitude)
|
|
26
|
+
- Identifies residential vs commercial addresses
|
|
27
|
+
|
|
28
|
+
Only use this tool if you specifically need to re-validate an existing address record by ID.
|
|
20
29
|
`,
|
|
21
30
|
scopes: ["read", "validation"],
|
|
22
31
|
annotations: {
|
|
@@ -0,0 +1,105 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* Code generated by Speakeasy (https://speakeasy.com). DO NOT EDIT.
|
|
3
|
+
*/
|
|
4
|
+
|
|
5
|
+
import { addressesValidateV2 } from "../../funcs/addressesValidateV2.js";
|
|
6
|
+
import { ValidateAddressV2Request$zodSchema } from "../../models/validateaddressv2op.js";
|
|
7
|
+
import { formatResult, ToolDefinition } from "../tools.js";
|
|
8
|
+
|
|
9
|
+
const args = {
|
|
10
|
+
request: ValidateAddressV2Request$zodSchema,
|
|
11
|
+
};
|
|
12
|
+
|
|
13
|
+
export const tool$addressesValidateV2: ToolDefinition<typeof args> = {
|
|
14
|
+
name: "addresses-validate-v2",
|
|
15
|
+
description:
|
|
16
|
+
`**PRIMARY ADDRESS VALIDATION TOOL** - Use this tool whenever asked to validate an address.
|
|
17
|
+
|
|
18
|
+
This is the recommended v2 validation endpoint that provides comprehensive results:
|
|
19
|
+
- Original address as submitted
|
|
20
|
+
- Recommended address with corrections
|
|
21
|
+
- Confidence score (high/medium/low)
|
|
22
|
+
- Validation result (valid/invalid/unknown)
|
|
23
|
+
- Address type (residential/commercial/unknown)
|
|
24
|
+
- List of changed attributes
|
|
25
|
+
- Geographic coordinates (latitude/longitude)
|
|
26
|
+
|
|
27
|
+
**Required Fields:**
|
|
28
|
+
- \`address_line_1\`: The street address (required)
|
|
29
|
+
- \`country_code\`: ISO 3166 country code (required)
|
|
30
|
+
|
|
31
|
+
**US Address Requirements (one of):**
|
|
32
|
+
- state_province + city_locality + address_line_1
|
|
33
|
+
- OR address_line_1 + postal_code
|
|
34
|
+
|
|
35
|
+
**International Requirements:**
|
|
36
|
+
- city_locality + address_line_1
|
|
37
|
+
|
|
38
|
+
**Example Request:**
|
|
39
|
+
\`\`\`
|
|
40
|
+
address_line_1: "731 Market Street"
|
|
41
|
+
address_line_2: "#200"
|
|
42
|
+
city_locality: "San Francisco"
|
|
43
|
+
state_province: "CA"
|
|
44
|
+
postal_code: "94103"
|
|
45
|
+
country_code: "US"
|
|
46
|
+
\`\`\`
|
|
47
|
+
|
|
48
|
+
**Example Response:**
|
|
49
|
+
\`\`\`json
|
|
50
|
+
{
|
|
51
|
+
"recommended_address": {
|
|
52
|
+
"address_line_1": "731 MARKET ST",
|
|
53
|
+
"city_locality": "SAN FRANCISCO",
|
|
54
|
+
"state_province": "CA",
|
|
55
|
+
"postal_code": "94103-2007",
|
|
56
|
+
"country_code": "US",
|
|
57
|
+
"confidence_result": {
|
|
58
|
+
"score": "high",
|
|
59
|
+
"description": "Address verified"
|
|
60
|
+
}
|
|
61
|
+
},
|
|
62
|
+
"analysis": {
|
|
63
|
+
"validation_result": {"value": "valid"},
|
|
64
|
+
"address_type": "commercial",
|
|
65
|
+
"changed_attributes": ["address_line_1", "postal_code"]
|
|
66
|
+
},
|
|
67
|
+
"geo": {"latitude": 37.7879, "longitude": -122.4074}
|
|
68
|
+
}
|
|
69
|
+
\`\`\`
|
|
70
|
+
|
|
71
|
+
**Use Cases:**
|
|
72
|
+
- Validate customer shipping addresses before label purchase
|
|
73
|
+
- Get corrected/standardized address formatting
|
|
74
|
+
- Determine if address is residential or commercial
|
|
75
|
+
- Get ZIP+4 extended postal codes
|
|
76
|
+
- Geocode addresses for mapping
|
|
77
|
+
`,
|
|
78
|
+
scopes: ["read", "validation"],
|
|
79
|
+
annotations: {
|
|
80
|
+
"title": "",
|
|
81
|
+
"destructiveHint": false,
|
|
82
|
+
"idempotentHint": false,
|
|
83
|
+
"openWorldHint": false,
|
|
84
|
+
"readOnlyHint": false,
|
|
85
|
+
},
|
|
86
|
+
args,
|
|
87
|
+
tool: async (client, args, ctx) => {
|
|
88
|
+
const [result, apiCall] = await addressesValidateV2(
|
|
89
|
+
client,
|
|
90
|
+
args.request,
|
|
91
|
+
{ fetchOptions: { signal: ctx.signal } },
|
|
92
|
+
).$inspect();
|
|
93
|
+
|
|
94
|
+
if (!result.ok) {
|
|
95
|
+
return {
|
|
96
|
+
content: [{ type: "text", text: result.error.message }],
|
|
97
|
+
isError: true,
|
|
98
|
+
};
|
|
99
|
+
}
|
|
100
|
+
|
|
101
|
+
const value = result.value;
|
|
102
|
+
|
|
103
|
+
return formatResult(value, apiCall);
|
|
104
|
+
},
|
|
105
|
+
};
|
|
@@ -0,0 +1,76 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* Code generated by Speakeasy (https://speakeasy.com). DO NOT EDIT.
|
|
3
|
+
*/
|
|
4
|
+
|
|
5
|
+
import { ordersGetPackingSlip } from "../../funcs/ordersGetPackingSlip.js";
|
|
6
|
+
import { GetOrderPackingSlipRequest$zodSchema } from "../../models/getorderpackingslipop.js";
|
|
7
|
+
import { formatResult, ToolDefinition } from "../tools.js";
|
|
8
|
+
|
|
9
|
+
const args = {
|
|
10
|
+
request: GetOrderPackingSlipRequest$zodSchema,
|
|
11
|
+
};
|
|
12
|
+
|
|
13
|
+
export const tool$ordersGetPackingSlip: ToolDefinition<typeof args> = {
|
|
14
|
+
name: "orders-get-packing-slip",
|
|
15
|
+
description:
|
|
16
|
+
`**GENERATE PACKING SLIP** - Creates a downloadable packing slip PDF for an order.
|
|
17
|
+
|
|
18
|
+
Use this tool when a customer needs a packing slip document for order fulfillment.
|
|
19
|
+
|
|
20
|
+
**Required Parameter:**
|
|
21
|
+
- \`OrderId\`: The order object ID (from orders-list or orders-create)
|
|
22
|
+
|
|
23
|
+
**Response:**
|
|
24
|
+
\`\`\`json
|
|
25
|
+
{
|
|
26
|
+
"slip_url": "https://shippo-delivery-east.s3.amazonaws.com/packingslip_{hash}.pdf?{signed_params}",
|
|
27
|
+
"created": "2026-01-07T16:58:46.350467",
|
|
28
|
+
"expires": "2026-01-08T16:58:46.350468"
|
|
29
|
+
}
|
|
30
|
+
\`\`\`
|
|
31
|
+
|
|
32
|
+
**Key Fields:**
|
|
33
|
+
- \`slip_url\`: Signed S3 URL to download the packing slip PDF (valid for 24 hours)
|
|
34
|
+
- \`created\`: When the packing slip was generated
|
|
35
|
+
- \`expires\`: When the download URL expires
|
|
36
|
+
|
|
37
|
+
**⚠️ URL HANDLING - CRITICAL:**
|
|
38
|
+
The \`slip_url\` is a signed S3 URL that contains required authentication parameters.
|
|
39
|
+
When displaying this URL:
|
|
40
|
+
- ALWAYS show the COMPLETE URL - NEVER truncate or replace parts with "..."
|
|
41
|
+
- S3 signed URLs will NOT work if modified or truncated
|
|
42
|
+
- Display the URL in a code block AND as a clickable hyperlink
|
|
43
|
+
|
|
44
|
+
**Example Usage:**
|
|
45
|
+
1. List orders: \`orders-list\` → Get an order ID
|
|
46
|
+
2. Generate packing slip: \`orders-get-packing-slip\` with OrderId
|
|
47
|
+
3. Download PDF from the returned \`slip_url\`
|
|
48
|
+
`,
|
|
49
|
+
scopes: ["read"],
|
|
50
|
+
annotations: {
|
|
51
|
+
"title": "",
|
|
52
|
+
"destructiveHint": false,
|
|
53
|
+
"idempotentHint": false,
|
|
54
|
+
"openWorldHint": false,
|
|
55
|
+
"readOnlyHint": false,
|
|
56
|
+
},
|
|
57
|
+
args,
|
|
58
|
+
tool: async (client, args, ctx) => {
|
|
59
|
+
const [result, apiCall] = await ordersGetPackingSlip(
|
|
60
|
+
client,
|
|
61
|
+
args.request,
|
|
62
|
+
{ fetchOptions: { signal: ctx.signal } },
|
|
63
|
+
).$inspect();
|
|
64
|
+
|
|
65
|
+
if (!result.ok) {
|
|
66
|
+
return {
|
|
67
|
+
content: [{ type: "text", text: result.error.message }],
|
|
68
|
+
isError: true,
|
|
69
|
+
};
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
const value = result.value;
|
|
73
|
+
|
|
74
|
+
return formatResult(value, apiCall);
|
|
75
|
+
},
|
|
76
|
+
};
|