@magic-ext/farcaster 0.0.6 → 0.0.7-canary.3d5e207.0

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/cjs/index.js CHANGED
@@ -1,2 +1,2 @@
1
- "use strict";var h=Object.defineProperty;var g=Object.getOwnPropertyDescriptor;var v=Object.getOwnPropertyNames;var R=Object.prototype.hasOwnProperty;var A=(t,n)=>{for(var e in n)h(t,e,{get:n[e],enumerable:!0})},C=(t,n,e,a)=>{if(n&&typeof n=="object"||typeof n=="function")for(let o of v(n))!R.call(t,o)&&o!==e&&h(t,o,{get:()=>n[o],enumerable:!(a=g(n,o))||a.enumerable});return t};var I=t=>C(h({},"__esModule",{value:!0}),t);var p=(t,n,e)=>new Promise((a,o)=>{var s=r=>{try{i(e.next(r))}catch(l){o(l)}},c=r=>{try{i(e.throw(r))}catch(l){o(l)}},i=r=>r.done?a(r.value):Promise.resolve(r.value).then(s,c);i((e=e.apply(t,n)).next())});var S={};A(S,{FarcasterExtension:()=>d});module.exports=I(S);var f=require("@magic-sdk/commons");function m(){return typeof navigator!="undefined"&&/android/i.test(navigator.userAgent)}function y(){return typeof navigator!="undefined"&&/iPhone|iPod/.test(navigator.userAgent)}function L(){return typeof navigator!="undefined"&&(/iPad/.test(navigator.userAgent)||navigator.platform==="MacIntel"&&navigator.maxTouchPoints>1)}function P(){return y()||L()}function u(){return m()||P()}var E=!0;var O="https://relay.farcaster.xyz",d=class extends f.Extension.Internal{constructor(){super();this.name="farcaster";this.config={};this.channel=null;this.login=e=>{var i;if(!this.channel)throw new Error("Channel not created yet.");let a=(i=e==null?void 0:e.showUI)!=null?i:E,o=location.origin,s=this.utils.createJsonRpcRequestPayload("farcaster_show_QR",[{data:{showUI:a,domain:o,isMobile:u(),channel:this.channel}}]),c=this.request(s);return u()&&(location.href=this.channel.url),c};p(this,null,function*(){let e=yield fetch(`${O}/v1/channel`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({domain:location.host,siweUri:location.origin})}).then(a=>a.json());this.channel=e})}};
1
+ "use strict";var u=Object.defineProperty;var f=Object.getOwnPropertyDescriptor;var C=Object.getOwnPropertyNames;var v=Object.prototype.hasOwnProperty;var A=(t,n)=>{for(var e in n)u(t,e,{get:n[e],enumerable:!0})},E=(t,n,e,o)=>{if(n&&typeof n=="object"||typeof n=="function")for(let r of C(n))!v.call(t,r)&&r!==e&&u(t,r,{get:()=>n[r],enumerable:!(o=f(n,r))||o.enumerable});return t};var b=t=>E(u({},"__esModule",{value:!0}),t);var g=(t,n,e)=>new Promise((o,r)=>{var s=a=>{try{i(e.next(a))}catch(c){r(c)}},l=a=>{try{i(e.throw(a))}catch(c){r(c)}},i=a=>a.done?o(a.value):Promise.resolve(a.value).then(s,l);i((e=e.apply(t,n)).next())});var O={};A(O,{FarcasterExtension:()=>h});module.exports=b(O);var p=require("@magic-sdk/commons");function m(){return typeof navigator!="undefined"&&/android/i.test(navigator.userAgent)}function w(){return typeof navigator!="undefined"&&/iPhone|iPod/.test(navigator.userAgent)}function y(){return typeof navigator!="undefined"&&(/iPad/.test(navigator.userAgent)||navigator.platform==="MacIntel"&&navigator.maxTouchPoints>1)}function R(){return w()||y()}function d(){return m()||R()}var x=!0;var I="https://relay.farcaster.xyz",h=class extends p.Extension.Internal{constructor(){super();this.name="farcaster";this.config={};this.channel=null;this.login=e=>{var i;if(!this.channel)throw new Error("Channel not created yet.");let o=(i=e==null?void 0:e.showUI)!=null?i:x,r=window.location.origin,s=this.utils.createJsonRpcRequestPayload("farcaster_show_QR",[{data:{showUI:o,domain:r,isMobile:d(),channel:this.channel}}]),l=this.request(s);return d()&&(window.location.href=this.channel.url),l};g(this,null,function*(){let e=yield fetch(`${I}/v1/channel`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({domain:window.location.host,siweUri:window.location.origin})}).then(o=>o.json());this.channel=e})}};
2
2
  //# sourceMappingURL=index.js.map
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../src/index.ts", "../../src/utils.ts"],
4
- "sourcesContent": ["import { Extension } from '@magic-sdk/commons';\nimport type { CreateChannelAPIResponse, AuthenticateAPIResponse, AuthClientError } from '@farcaster/auth-client';\nimport { FarcasterPayloadMethod } from './types';\nimport { isMobile } from './utils';\n\nconst DEFAULT_SHOW_UI = true;\n\ntype LoginParams = {\n showUI: boolean;\n};\n\nconst FarcasterLoginEventOnReceived = {\n OpenChannel: 'channel',\n Success: 'success',\n Failed: 'failed',\n} as const;\n\ntype FarcasterLoginEventHandlers = {\n [FarcasterLoginEventOnReceived.OpenChannel]: (channel: CreateChannelAPIResponse) => void;\n [FarcasterLoginEventOnReceived.Success]: (data: AuthenticateAPIResponse) => void;\n [FarcasterLoginEventOnReceived.Failed]: (error: AuthClientError) => void;\n};\n\nconst FARCASTER_RELAY_URL = 'https://relay.farcaster.xyz';\nexport class FarcasterExtension extends Extension.Internal<'farcaster'> {\n name = 'farcaster' as const;\n config = {};\n channel: CreateChannelAPIResponse | null = null;\n\n constructor() {\n super();\n\n (async () => {\n const json = await fetch(`${FARCASTER_RELAY_URL}/v1/channel`, {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json',\n },\n body: JSON.stringify({\n domain: location.host,\n siweUri: location.origin,\n }),\n }).then<CreateChannelAPIResponse>((r) => r.json());\n\n this.channel = json;\n })();\n }\n\n public login = (params?: LoginParams) => {\n if (!this.channel) {\n throw new Error('Channel not created yet.');\n }\n\n const showUI = params?.showUI ?? DEFAULT_SHOW_UI;\n\n const domain = location.origin;\n\n const payload = this.utils.createJsonRpcRequestPayload(FarcasterPayloadMethod.FarcasterShowQR, [\n {\n data: {\n showUI,\n domain,\n isMobile: isMobile(),\n channel: this.channel,\n },\n },\n ]);\n\n const handle = this.request<string, FarcasterLoginEventHandlers>(payload);\n\n if (isMobile()) {\n location.href = this.channel.url;\n }\n\n return handle;\n };\n}\n", "// https://github.com/farcasterxyz/auth-monorepo/blob/main/packages/auth-kit/src/utils.ts\n\nexport function isAndroid(): boolean {\n return typeof navigator !== 'undefined' && /android/i.test(navigator.userAgent);\n}\n\nexport function isSmallIOS(): boolean {\n return typeof navigator !== 'undefined' && /iPhone|iPod/.test(navigator.userAgent);\n}\n\nexport function isLargeIOS(): boolean {\n return (\n typeof navigator !== 'undefined' &&\n (/iPad/.test(navigator.userAgent) || (navigator.platform === 'MacIntel' && navigator.maxTouchPoints > 1))\n );\n}\n\nexport function isIOS(): boolean {\n return isSmallIOS() || isLargeIOS();\n}\n\nexport function isMobile(): boolean {\n return isAndroid() || isIOS();\n}\n"],
5
- "mappings": "snBAAA,IAAAA,EAAA,GAAAC,EAAAD,EAAA,wBAAAE,IAAA,eAAAC,EAAAH,GAAA,IAAAI,EAA0B,8BCEnB,SAASC,GAAqB,CACnC,OAAO,OAAO,WAAc,aAAe,WAAW,KAAK,UAAU,SAAS,CAChF,CAEO,SAASC,GAAsB,CACpC,OAAO,OAAO,WAAc,aAAe,cAAc,KAAK,UAAU,SAAS,CACnF,CAEO,SAASC,GAAsB,CACpC,OACE,OAAO,WAAc,cACpB,OAAO,KAAK,UAAU,SAAS,GAAM,UAAU,WAAa,YAAc,UAAU,eAAiB,EAE1G,CAEO,SAASC,GAAiB,CAC/B,OAAOF,EAAW,GAAKC,EAAW,CACpC,CAEO,SAASE,GAAoB,CAClC,OAAOJ,EAAU,GAAKG,EAAM,CAC9B,CDlBA,IAAME,EAAkB,GAkBxB,IAAMC,EAAsB,8BACfC,EAAN,cAAiC,YAAU,QAAsB,CAKtE,aAAc,CACZ,MAAM,EALR,UAAO,YACP,YAAS,CAAC,EACV,aAA2C,KAqB3C,KAAO,MAASC,GAAyB,CAhD3C,IAAAC,EAiDI,GAAI,CAAC,KAAK,QACR,MAAM,IAAI,MAAM,0BAA0B,EAG5C,IAAMC,GAASD,EAAAD,GAAA,YAAAA,EAAQ,SAAR,KAAAC,EAAkBE,EAE3BC,EAAS,SAAS,OAElBC,EAAU,KAAK,MAAM,gDAAoE,CAC7F,CACE,KAAM,CACJ,OAAAH,EACA,OAAAE,EACA,SAAUE,EAAS,EACnB,QAAS,KAAK,OAChB,CACF,CACF,CAAC,EAEKC,EAAS,KAAK,QAA6CF,CAAO,EAExE,OAAIC,EAAS,IACX,SAAS,KAAO,KAAK,QAAQ,KAGxBC,CACT,EA3CeC,EAAA,sBACX,IAAMC,EAAO,MAAM,MAAM,GAAGX,eAAkC,CAC5D,OAAQ,OACR,QAAS,CACP,eAAgB,kBAClB,EACA,KAAM,KAAK,UAAU,CACnB,OAAQ,SAAS,KACjB,QAAS,SAAS,MACpB,CAAC,CACH,CAAC,EAAE,KAAgCY,GAAMA,EAAE,KAAK,CAAC,EAEjD,KAAK,QAAUD,CACjB,EACF,CA8BF",
4
+ "sourcesContent": ["import { Extension } from '@magic-sdk/commons';\nimport { FarcasterPayloadMethod } from './types';\nimport { isMobile } from './utils';\n\nconst DEFAULT_SHOW_UI = true;\n\ntype LoginParams = {\n showUI: boolean;\n};\n\nconst FarcasterLoginEventOnReceived = {\n OpenChannel: 'channel',\n Success: 'success',\n Failed: 'failed',\n} as const;\n\ninterface CreateChannelAPIResponse {\n channelToken: string;\n url: string;\n nonce: string;\n}\n\ntype Hex = `0x${string}`;\n\ninterface StatusAPIResponse {\n state: 'pending' | 'completed';\n nonce: string;\n url: string;\n message?: string;\n signature?: `0x${string}`;\n fid?: number;\n username?: string;\n bio?: string;\n displayName?: string;\n pfpUrl?: string;\n verifications?: Hex[];\n custody?: Hex;\n}\n\ntype AuthClientErrorCode =\n | 'unauthenticated'\n | 'unauthorized'\n | 'bad_request'\n | 'bad_request.validation_failure'\n | 'not_found'\n | 'not_implemented'\n | 'unavailable'\n | 'unknown';\n\ninterface AuthClientErrorOpts {\n message: string;\n cause: Error | AuthClientError;\n presentable: boolean;\n}\n\ndeclare class AuthClientError extends Error {\n readonly errCode: AuthClientErrorCode;\n readonly presentable: boolean;\n /**\n * @param errCode - the AuthClientError code for this message\n * @param context - a message, another Error, or a AuthClientErrorOpts\n */\n constructor(errCode: AuthClientErrorCode, context: Partial<AuthClientErrorOpts> | string | Error);\n}\n\ntype FarcasterLoginEventHandlers = {\n [FarcasterLoginEventOnReceived.OpenChannel]: (channel: CreateChannelAPIResponse) => void;\n [FarcasterLoginEventOnReceived.Success]: (data: StatusAPIResponse) => void;\n [FarcasterLoginEventOnReceived.Failed]: (error: AuthClientError) => void;\n};\n\nconst FARCASTER_RELAY_URL = 'https://relay.farcaster.xyz';\nexport class FarcasterExtension extends Extension.Internal<'farcaster'> {\n name = 'farcaster' as const;\n config = {};\n channel: CreateChannelAPIResponse | null = null;\n\n constructor() {\n super();\n\n (async () => {\n const json = await fetch(`${FARCASTER_RELAY_URL}/v1/channel`, {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json',\n },\n body: JSON.stringify({\n domain: window.location.host,\n siweUri: window.location.origin,\n }),\n }).then<CreateChannelAPIResponse>((r) => r.json());\n\n this.channel = json;\n })();\n }\n\n public login = (params?: LoginParams) => {\n if (!this.channel) {\n throw new Error('Channel not created yet.');\n }\n\n const showUI = params?.showUI ?? DEFAULT_SHOW_UI;\n\n const domain = window.location.origin;\n\n const payload = this.utils.createJsonRpcRequestPayload(FarcasterPayloadMethod.FarcasterShowQR, [\n {\n data: {\n showUI,\n domain,\n isMobile: isMobile(),\n channel: this.channel,\n },\n },\n ]);\n\n const handle = this.request<string, FarcasterLoginEventHandlers>(payload);\n\n if (isMobile()) {\n window.location.href = this.channel.url;\n }\n\n return handle;\n };\n}\n", "// https://github.com/farcasterxyz/auth-monorepo/blob/main/packages/auth-kit/src/utils.ts\n\nexport function isAndroid(): boolean {\n return typeof navigator !== 'undefined' && /android/i.test(navigator.userAgent);\n}\n\nexport function isSmallIOS(): boolean {\n return typeof navigator !== 'undefined' && /iPhone|iPod/.test(navigator.userAgent);\n}\n\nexport function isLargeIOS(): boolean {\n return (\n typeof navigator !== 'undefined' &&\n (/iPad/.test(navigator.userAgent) || (navigator.platform === 'MacIntel' && navigator.maxTouchPoints > 1))\n );\n}\n\nexport function isIOS(): boolean {\n return isSmallIOS() || isLargeIOS();\n}\n\nexport function isMobile(): boolean {\n return isAndroid() || isIOS();\n}\n"],
5
+ "mappings": "snBAAA,IAAAA,EAAA,GAAAC,EAAAD,EAAA,wBAAAE,IAAA,eAAAC,EAAAH,GAAA,IAAAI,EAA0B,8BCEnB,SAASC,GAAqB,CACnC,OAAO,OAAO,WAAc,aAAe,WAAW,KAAK,UAAU,SAAS,CAChF,CAEO,SAASC,GAAsB,CACpC,OAAO,OAAO,WAAc,aAAe,cAAc,KAAK,UAAU,SAAS,CACnF,CAEO,SAASC,GAAsB,CACpC,OACE,OAAO,WAAc,cACpB,OAAO,KAAK,UAAU,SAAS,GAAM,UAAU,WAAa,YAAc,UAAU,eAAiB,EAE1G,CAEO,SAASC,GAAiB,CAC/B,OAAOF,EAAW,GAAKC,EAAW,CACpC,CAEO,SAASE,GAAoB,CAClC,OAAOJ,EAAU,GAAKG,EAAM,CAC9B,CDnBA,IAAME,EAAkB,GAmExB,IAAMC,EAAsB,8BACfC,EAAN,cAAiC,YAAU,QAAsB,CAKtE,aAAc,CACZ,MAAM,EALR,UAAO,YACP,YAAS,CAAC,EACV,aAA2C,KAqB3C,KAAO,MAASC,GAAyB,CAhG3C,IAAAC,EAiGI,GAAI,CAAC,KAAK,QACR,MAAM,IAAI,MAAM,0BAA0B,EAG5C,IAAMC,GAASD,EAAAD,GAAA,YAAAA,EAAQ,SAAR,KAAAC,EAAkBE,EAE3BC,EAAS,OAAO,SAAS,OAEzBC,EAAU,KAAK,MAAM,gDAAoE,CAC7F,CACE,KAAM,CACJ,OAAAH,EACA,OAAAE,EACA,SAAUE,EAAS,EACnB,QAAS,KAAK,OAChB,CACF,CACF,CAAC,EAEKC,EAAS,KAAK,QAA6CF,CAAO,EAExE,OAAIC,EAAS,IACX,OAAO,SAAS,KAAO,KAAK,QAAQ,KAG/BC,CACT,EA3CeC,EAAA,sBACX,IAAMC,EAAO,MAAM,MAAM,GAAGX,eAAkC,CAC5D,OAAQ,OACR,QAAS,CACP,eAAgB,kBAClB,EACA,KAAM,KAAK,UAAU,CACnB,OAAQ,OAAO,SAAS,KACxB,QAAS,OAAO,SAAS,MAC3B,CAAC,CACH,CAAC,EAAE,KAAgCY,GAAMA,EAAE,KAAK,CAAC,EAEjD,KAAK,QAAUD,CACjB,EACF,CA8BF",
6
6
  "names": ["src_exports", "__export", "FarcasterExtension", "__toCommonJS", "import_commons", "isAndroid", "isSmallIOS", "isLargeIOS", "isIOS", "isMobile", "DEFAULT_SHOW_UI", "FARCASTER_RELAY_URL", "FarcasterExtension", "params", "_a", "showUI", "DEFAULT_SHOW_UI", "domain", "payload", "isMobile", "handle", "__async", "json", "r"]
7
7
  }
package/dist/es/index.js CHANGED
@@ -1,2 +1,2 @@
1
- var u=(l,h,e)=>new Promise((o,a)=>{var r=n=>{try{t(e.next(n))}catch(s){a(s)}},i=n=>{try{t(e.throw(n))}catch(s){a(s)}},t=n=>n.done?o(n.value):Promise.resolve(n.value).then(r,i);t((e=e.apply(l,h)).next())});import{Extension as R}from"@magic-sdk/commons";function p(){return typeof navigator!="undefined"&&/android/i.test(navigator.userAgent)}function f(){return typeof navigator!="undefined"&&/iPhone|iPod/.test(navigator.userAgent)}function g(){return typeof navigator!="undefined"&&(/iPad/.test(navigator.userAgent)||navigator.platform==="MacIntel"&&navigator.maxTouchPoints>1)}function v(){return f()||g()}function c(){return p()||v()}var A=!0;var C="https://relay.farcaster.xyz",d=class extends R.Internal{constructor(){super();this.name="farcaster";this.config={};this.channel=null;this.login=e=>{var t;if(!this.channel)throw new Error("Channel not created yet.");let o=(t=e==null?void 0:e.showUI)!=null?t:A,a=location.origin,r=this.utils.createJsonRpcRequestPayload("farcaster_show_QR",[{data:{showUI:o,domain:a,isMobile:c(),channel:this.channel}}]),i=this.request(r);return c()&&(location.href=this.channel.url),i};u(this,null,function*(){let e=yield fetch(`${C}/v1/channel`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({domain:location.host,siweUri:location.origin})}).then(o=>o.json());this.channel=e})}};export{d as FarcasterExtension};
1
+ var d=(c,u,e)=>new Promise((r,o)=>{var a=n=>{try{t(e.next(n))}catch(s){o(s)}},i=n=>{try{t(e.throw(n))}catch(s){o(s)}},t=n=>n.done?r(n.value):Promise.resolve(n.value).then(a,i);t((e=e.apply(c,u)).next())});import{Extension as v}from"@magic-sdk/commons";function g(){return typeof navigator!="undefined"&&/android/i.test(navigator.userAgent)}function p(){return typeof navigator!="undefined"&&/iPhone|iPod/.test(navigator.userAgent)}function f(){return typeof navigator!="undefined"&&(/iPad/.test(navigator.userAgent)||navigator.platform==="MacIntel"&&navigator.maxTouchPoints>1)}function C(){return p()||f()}function l(){return g()||C()}var A=!0;var E="https://relay.farcaster.xyz",h=class extends v.Internal{constructor(){super();this.name="farcaster";this.config={};this.channel=null;this.login=e=>{var t;if(!this.channel)throw new Error("Channel not created yet.");let r=(t=e==null?void 0:e.showUI)!=null?t:A,o=window.location.origin,a=this.utils.createJsonRpcRequestPayload("farcaster_show_QR",[{data:{showUI:r,domain:o,isMobile:l(),channel:this.channel}}]),i=this.request(a);return l()&&(window.location.href=this.channel.url),i};d(this,null,function*(){let e=yield fetch(`${E}/v1/channel`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({domain:window.location.host,siweUri:window.location.origin})}).then(r=>r.json());this.channel=e})}};export{h as FarcasterExtension};
2
2
  //# sourceMappingURL=index.js.map
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../src/index.ts", "../../src/utils.ts"],
4
- "sourcesContent": ["import { Extension } from '@magic-sdk/commons';\nimport type { CreateChannelAPIResponse, AuthenticateAPIResponse, AuthClientError } from '@farcaster/auth-client';\nimport { FarcasterPayloadMethod } from './types';\nimport { isMobile } from './utils';\n\nconst DEFAULT_SHOW_UI = true;\n\ntype LoginParams = {\n showUI: boolean;\n};\n\nconst FarcasterLoginEventOnReceived = {\n OpenChannel: 'channel',\n Success: 'success',\n Failed: 'failed',\n} as const;\n\ntype FarcasterLoginEventHandlers = {\n [FarcasterLoginEventOnReceived.OpenChannel]: (channel: CreateChannelAPIResponse) => void;\n [FarcasterLoginEventOnReceived.Success]: (data: AuthenticateAPIResponse) => void;\n [FarcasterLoginEventOnReceived.Failed]: (error: AuthClientError) => void;\n};\n\nconst FARCASTER_RELAY_URL = 'https://relay.farcaster.xyz';\nexport class FarcasterExtension extends Extension.Internal<'farcaster'> {\n name = 'farcaster' as const;\n config = {};\n channel: CreateChannelAPIResponse | null = null;\n\n constructor() {\n super();\n\n (async () => {\n const json = await fetch(`${FARCASTER_RELAY_URL}/v1/channel`, {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json',\n },\n body: JSON.stringify({\n domain: location.host,\n siweUri: location.origin,\n }),\n }).then<CreateChannelAPIResponse>((r) => r.json());\n\n this.channel = json;\n })();\n }\n\n public login = (params?: LoginParams) => {\n if (!this.channel) {\n throw new Error('Channel not created yet.');\n }\n\n const showUI = params?.showUI ?? DEFAULT_SHOW_UI;\n\n const domain = location.origin;\n\n const payload = this.utils.createJsonRpcRequestPayload(FarcasterPayloadMethod.FarcasterShowQR, [\n {\n data: {\n showUI,\n domain,\n isMobile: isMobile(),\n channel: this.channel,\n },\n },\n ]);\n\n const handle = this.request<string, FarcasterLoginEventHandlers>(payload);\n\n if (isMobile()) {\n location.href = this.channel.url;\n }\n\n return handle;\n };\n}\n", "// https://github.com/farcasterxyz/auth-monorepo/blob/main/packages/auth-kit/src/utils.ts\n\nexport function isAndroid(): boolean {\n return typeof navigator !== 'undefined' && /android/i.test(navigator.userAgent);\n}\n\nexport function isSmallIOS(): boolean {\n return typeof navigator !== 'undefined' && /iPhone|iPod/.test(navigator.userAgent);\n}\n\nexport function isLargeIOS(): boolean {\n return (\n typeof navigator !== 'undefined' &&\n (/iPad/.test(navigator.userAgent) || (navigator.platform === 'MacIntel' && navigator.maxTouchPoints > 1))\n );\n}\n\nexport function isIOS(): boolean {\n return isSmallIOS() || isLargeIOS();\n}\n\nexport function isMobile(): boolean {\n return isAndroid() || isIOS();\n}\n"],
5
- "mappings": "6MAAA,OAAS,aAAAA,MAAiB,qBCEnB,SAASC,GAAqB,CACnC,OAAO,OAAO,WAAc,aAAe,WAAW,KAAK,UAAU,SAAS,CAChF,CAEO,SAASC,GAAsB,CACpC,OAAO,OAAO,WAAc,aAAe,cAAc,KAAK,UAAU,SAAS,CACnF,CAEO,SAASC,GAAsB,CACpC,OACE,OAAO,WAAc,cACpB,OAAO,KAAK,UAAU,SAAS,GAAM,UAAU,WAAa,YAAc,UAAU,eAAiB,EAE1G,CAEO,SAASC,GAAiB,CAC/B,OAAOF,EAAW,GAAKC,EAAW,CACpC,CAEO,SAASE,GAAoB,CAClC,OAAOJ,EAAU,GAAKG,EAAM,CAC9B,CDlBA,IAAME,EAAkB,GAkBxB,IAAMC,EAAsB,8BACfC,EAAN,cAAiCC,EAAU,QAAsB,CAKtE,aAAc,CACZ,MAAM,EALR,UAAO,YACP,YAAS,CAAC,EACV,aAA2C,KAqB3C,KAAO,MAASC,GAAyB,CAhD3C,IAAAC,EAiDI,GAAI,CAAC,KAAK,QACR,MAAM,IAAI,MAAM,0BAA0B,EAG5C,IAAMC,GAASD,EAAAD,GAAA,YAAAA,EAAQ,SAAR,KAAAC,EAAkBE,EAE3BC,EAAS,SAAS,OAElBC,EAAU,KAAK,MAAM,gDAAoE,CAC7F,CACE,KAAM,CACJ,OAAAH,EACA,OAAAE,EACA,SAAUE,EAAS,EACnB,QAAS,KAAK,OAChB,CACF,CACF,CAAC,EAEKC,EAAS,KAAK,QAA6CF,CAAO,EAExE,OAAIC,EAAS,IACX,SAAS,KAAO,KAAK,QAAQ,KAGxBC,CACT,EA3CeC,EAAA,sBACX,IAAMC,EAAO,MAAM,MAAM,GAAGZ,eAAkC,CAC5D,OAAQ,OACR,QAAS,CACP,eAAgB,kBAClB,EACA,KAAM,KAAK,UAAU,CACnB,OAAQ,SAAS,KACjB,QAAS,SAAS,MACpB,CAAC,CACH,CAAC,EAAE,KAAgCa,GAAMA,EAAE,KAAK,CAAC,EAEjD,KAAK,QAAUD,CACjB,EACF,CA8BF",
6
- "names": ["Extension", "isAndroid", "isSmallIOS", "isLargeIOS", "isIOS", "isMobile", "DEFAULT_SHOW_UI", "FARCASTER_RELAY_URL", "FarcasterExtension", "Extension", "params", "_a", "showUI", "DEFAULT_SHOW_UI", "domain", "payload", "isMobile", "handle", "__async", "json", "r"]
4
+ "sourcesContent": ["import { Extension } from '@magic-sdk/commons';\nimport { FarcasterPayloadMethod } from './types';\nimport { isMobile } from './utils';\n\nconst DEFAULT_SHOW_UI = true;\n\ntype LoginParams = {\n showUI: boolean;\n};\n\nconst FarcasterLoginEventOnReceived = {\n OpenChannel: 'channel',\n Success: 'success',\n Failed: 'failed',\n} as const;\n\ninterface CreateChannelAPIResponse {\n channelToken: string;\n url: string;\n nonce: string;\n}\n\ntype Hex = `0x${string}`;\n\ninterface StatusAPIResponse {\n state: 'pending' | 'completed';\n nonce: string;\n url: string;\n message?: string;\n signature?: `0x${string}`;\n fid?: number;\n username?: string;\n bio?: string;\n displayName?: string;\n pfpUrl?: string;\n verifications?: Hex[];\n custody?: Hex;\n}\n\ntype AuthClientErrorCode =\n | 'unauthenticated'\n | 'unauthorized'\n | 'bad_request'\n | 'bad_request.validation_failure'\n | 'not_found'\n | 'not_implemented'\n | 'unavailable'\n | 'unknown';\n\ninterface AuthClientErrorOpts {\n message: string;\n cause: Error | AuthClientError;\n presentable: boolean;\n}\n\ndeclare class AuthClientError extends Error {\n readonly errCode: AuthClientErrorCode;\n readonly presentable: boolean;\n /**\n * @param errCode - the AuthClientError code for this message\n * @param context - a message, another Error, or a AuthClientErrorOpts\n */\n constructor(errCode: AuthClientErrorCode, context: Partial<AuthClientErrorOpts> | string | Error);\n}\n\ntype FarcasterLoginEventHandlers = {\n [FarcasterLoginEventOnReceived.OpenChannel]: (channel: CreateChannelAPIResponse) => void;\n [FarcasterLoginEventOnReceived.Success]: (data: StatusAPIResponse) => void;\n [FarcasterLoginEventOnReceived.Failed]: (error: AuthClientError) => void;\n};\n\nconst FARCASTER_RELAY_URL = 'https://relay.farcaster.xyz';\nexport class FarcasterExtension extends Extension.Internal<'farcaster'> {\n name = 'farcaster' as const;\n config = {};\n channel: CreateChannelAPIResponse | null = null;\n\n constructor() {\n super();\n\n (async () => {\n const json = await fetch(`${FARCASTER_RELAY_URL}/v1/channel`, {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json',\n },\n body: JSON.stringify({\n domain: window.location.host,\n siweUri: window.location.origin,\n }),\n }).then<CreateChannelAPIResponse>((r) => r.json());\n\n this.channel = json;\n })();\n }\n\n public login = (params?: LoginParams) => {\n if (!this.channel) {\n throw new Error('Channel not created yet.');\n }\n\n const showUI = params?.showUI ?? DEFAULT_SHOW_UI;\n\n const domain = window.location.origin;\n\n const payload = this.utils.createJsonRpcRequestPayload(FarcasterPayloadMethod.FarcasterShowQR, [\n {\n data: {\n showUI,\n domain,\n isMobile: isMobile(),\n channel: this.channel,\n },\n },\n ]);\n\n const handle = this.request<string, FarcasterLoginEventHandlers>(payload);\n\n if (isMobile()) {\n window.location.href = this.channel.url;\n }\n\n return handle;\n };\n}\n", "// https://github.com/farcasterxyz/auth-monorepo/blob/main/packages/auth-kit/src/utils.ts\n\nexport function isAndroid(): boolean {\n return typeof navigator !== 'undefined' && /android/i.test(navigator.userAgent);\n}\n\nexport function isSmallIOS(): boolean {\n return typeof navigator !== 'undefined' && /iPhone|iPod/.test(navigator.userAgent);\n}\n\nexport function isLargeIOS(): boolean {\n return (\n typeof navigator !== 'undefined' &&\n (/iPad/.test(navigator.userAgent) || (navigator.platform === 'MacIntel' && navigator.maxTouchPoints > 1))\n );\n}\n\nexport function isIOS(): boolean {\n return isSmallIOS() || isLargeIOS();\n}\n\nexport function isMobile(): boolean {\n return isAndroid() || isIOS();\n}\n"],
5
+ "mappings": "6MAAA,OAAS,aAAAA,MAAiB,qBCEnB,SAASC,GAAqB,CACnC,OAAO,OAAO,WAAc,aAAe,WAAW,KAAK,UAAU,SAAS,CAChF,CAEO,SAASC,GAAsB,CACpC,OAAO,OAAO,WAAc,aAAe,cAAc,KAAK,UAAU,SAAS,CACnF,CAEO,SAASC,GAAsB,CACpC,OACE,OAAO,WAAc,cACpB,OAAO,KAAK,UAAU,SAAS,GAAM,UAAU,WAAa,YAAc,UAAU,eAAiB,EAE1G,CAEO,SAASC,GAAiB,CAC/B,OAAOF,EAAW,GAAKC,EAAW,CACpC,CAEO,SAASE,GAAoB,CAClC,OAAOJ,EAAU,GAAKG,EAAM,CAC9B,CDnBA,IAAME,EAAkB,GAmExB,IAAMC,EAAsB,8BACfC,EAAN,cAAiCC,EAAU,QAAsB,CAKtE,aAAc,CACZ,MAAM,EALR,UAAO,YACP,YAAS,CAAC,EACV,aAA2C,KAqB3C,KAAO,MAASC,GAAyB,CAhG3C,IAAAC,EAiGI,GAAI,CAAC,KAAK,QACR,MAAM,IAAI,MAAM,0BAA0B,EAG5C,IAAMC,GAASD,EAAAD,GAAA,YAAAA,EAAQ,SAAR,KAAAC,EAAkBE,EAE3BC,EAAS,OAAO,SAAS,OAEzBC,EAAU,KAAK,MAAM,gDAAoE,CAC7F,CACE,KAAM,CACJ,OAAAH,EACA,OAAAE,EACA,SAAUE,EAAS,EACnB,QAAS,KAAK,OAChB,CACF,CACF,CAAC,EAEKC,EAAS,KAAK,QAA6CF,CAAO,EAExE,OAAIC,EAAS,IACX,OAAO,SAAS,KAAO,KAAK,QAAQ,KAG/BC,CACT,EA3CeC,EAAA,sBACX,IAAMC,EAAO,MAAM,MAAM,GAAGZ,eAAkC,CAC5D,OAAQ,OACR,QAAS,CACP,eAAgB,kBAClB,EACA,KAAM,KAAK,UAAU,CACnB,OAAQ,OAAO,SAAS,KACxB,QAAS,OAAO,SAAS,MAC3B,CAAC,CACH,CAAC,EAAE,KAAgC,GAAM,EAAE,KAAK,CAAC,EAEjD,KAAK,QAAUY,CACjB,EACF,CA8BF",
6
+ "names": ["Extension", "isAndroid", "isSmallIOS", "isLargeIOS", "isIOS", "isMobile", "DEFAULT_SHOW_UI", "FARCASTER_RELAY_URL", "FarcasterExtension", "Extension", "params", "_a", "showUI", "DEFAULT_SHOW_UI", "domain", "payload", "isMobile", "handle", "__async", "json"]
7
7
  }
package/dist/es/index.mjs CHANGED
@@ -1,2 +1,2 @@
1
- var u=(l,h,e)=>new Promise((o,a)=>{var r=n=>{try{t(e.next(n))}catch(s){a(s)}},i=n=>{try{t(e.throw(n))}catch(s){a(s)}},t=n=>n.done?o(n.value):Promise.resolve(n.value).then(r,i);t((e=e.apply(l,h)).next())});import{Extension as R}from"@magic-sdk/commons";function p(){return typeof navigator!="undefined"&&/android/i.test(navigator.userAgent)}function f(){return typeof navigator!="undefined"&&/iPhone|iPod/.test(navigator.userAgent)}function g(){return typeof navigator!="undefined"&&(/iPad/.test(navigator.userAgent)||navigator.platform==="MacIntel"&&navigator.maxTouchPoints>1)}function v(){return f()||g()}function c(){return p()||v()}var A=!0;var C="https://relay.farcaster.xyz",d=class extends R.Internal{constructor(){super();this.name="farcaster";this.config={};this.channel=null;this.login=e=>{var t;if(!this.channel)throw new Error("Channel not created yet.");let o=(t=e==null?void 0:e.showUI)!=null?t:A,a=location.origin,r=this.utils.createJsonRpcRequestPayload("farcaster_show_QR",[{data:{showUI:o,domain:a,isMobile:c(),channel:this.channel}}]),i=this.request(r);return c()&&(location.href=this.channel.url),i};u(this,null,function*(){let e=yield fetch(`${C}/v1/channel`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({domain:location.host,siweUri:location.origin})}).then(o=>o.json());this.channel=e})}};export{d as FarcasterExtension};
1
+ var d=(c,u,e)=>new Promise((r,o)=>{var a=n=>{try{t(e.next(n))}catch(s){o(s)}},i=n=>{try{t(e.throw(n))}catch(s){o(s)}},t=n=>n.done?r(n.value):Promise.resolve(n.value).then(a,i);t((e=e.apply(c,u)).next())});import{Extension as v}from"@magic-sdk/commons";function g(){return typeof navigator!="undefined"&&/android/i.test(navigator.userAgent)}function p(){return typeof navigator!="undefined"&&/iPhone|iPod/.test(navigator.userAgent)}function f(){return typeof navigator!="undefined"&&(/iPad/.test(navigator.userAgent)||navigator.platform==="MacIntel"&&navigator.maxTouchPoints>1)}function C(){return p()||f()}function l(){return g()||C()}var A=!0;var E="https://relay.farcaster.xyz",h=class extends v.Internal{constructor(){super();this.name="farcaster";this.config={};this.channel=null;this.login=e=>{var t;if(!this.channel)throw new Error("Channel not created yet.");let r=(t=e==null?void 0:e.showUI)!=null?t:A,o=window.location.origin,a=this.utils.createJsonRpcRequestPayload("farcaster_show_QR",[{data:{showUI:r,domain:o,isMobile:l(),channel:this.channel}}]),i=this.request(a);return l()&&(window.location.href=this.channel.url),i};d(this,null,function*(){let e=yield fetch(`${E}/v1/channel`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({domain:window.location.host,siweUri:window.location.origin})}).then(r=>r.json());this.channel=e})}};export{h as FarcasterExtension};
2
2
  //# sourceMappingURL=index.mjs.map
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../src/index.ts", "../../src/utils.ts"],
4
- "sourcesContent": ["import { Extension } from '@magic-sdk/commons';\nimport type { CreateChannelAPIResponse, AuthenticateAPIResponse, AuthClientError } from '@farcaster/auth-client';\nimport { FarcasterPayloadMethod } from './types';\nimport { isMobile } from './utils';\n\nconst DEFAULT_SHOW_UI = true;\n\ntype LoginParams = {\n showUI: boolean;\n};\n\nconst FarcasterLoginEventOnReceived = {\n OpenChannel: 'channel',\n Success: 'success',\n Failed: 'failed',\n} as const;\n\ntype FarcasterLoginEventHandlers = {\n [FarcasterLoginEventOnReceived.OpenChannel]: (channel: CreateChannelAPIResponse) => void;\n [FarcasterLoginEventOnReceived.Success]: (data: AuthenticateAPIResponse) => void;\n [FarcasterLoginEventOnReceived.Failed]: (error: AuthClientError) => void;\n};\n\nconst FARCASTER_RELAY_URL = 'https://relay.farcaster.xyz';\nexport class FarcasterExtension extends Extension.Internal<'farcaster'> {\n name = 'farcaster' as const;\n config = {};\n channel: CreateChannelAPIResponse | null = null;\n\n constructor() {\n super();\n\n (async () => {\n const json = await fetch(`${FARCASTER_RELAY_URL}/v1/channel`, {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json',\n },\n body: JSON.stringify({\n domain: location.host,\n siweUri: location.origin,\n }),\n }).then<CreateChannelAPIResponse>((r) => r.json());\n\n this.channel = json;\n })();\n }\n\n public login = (params?: LoginParams) => {\n if (!this.channel) {\n throw new Error('Channel not created yet.');\n }\n\n const showUI = params?.showUI ?? DEFAULT_SHOW_UI;\n\n const domain = location.origin;\n\n const payload = this.utils.createJsonRpcRequestPayload(FarcasterPayloadMethod.FarcasterShowQR, [\n {\n data: {\n showUI,\n domain,\n isMobile: isMobile(),\n channel: this.channel,\n },\n },\n ]);\n\n const handle = this.request<string, FarcasterLoginEventHandlers>(payload);\n\n if (isMobile()) {\n location.href = this.channel.url;\n }\n\n return handle;\n };\n}\n", "// https://github.com/farcasterxyz/auth-monorepo/blob/main/packages/auth-kit/src/utils.ts\n\nexport function isAndroid(): boolean {\n return typeof navigator !== 'undefined' && /android/i.test(navigator.userAgent);\n}\n\nexport function isSmallIOS(): boolean {\n return typeof navigator !== 'undefined' && /iPhone|iPod/.test(navigator.userAgent);\n}\n\nexport function isLargeIOS(): boolean {\n return (\n typeof navigator !== 'undefined' &&\n (/iPad/.test(navigator.userAgent) || (navigator.platform === 'MacIntel' && navigator.maxTouchPoints > 1))\n );\n}\n\nexport function isIOS(): boolean {\n return isSmallIOS() || isLargeIOS();\n}\n\nexport function isMobile(): boolean {\n return isAndroid() || isIOS();\n}\n"],
5
- "mappings": "6MAAA,OAAS,aAAAA,MAAiB,qBCEnB,SAASC,GAAqB,CACnC,OAAO,OAAO,WAAc,aAAe,WAAW,KAAK,UAAU,SAAS,CAChF,CAEO,SAASC,GAAsB,CACpC,OAAO,OAAO,WAAc,aAAe,cAAc,KAAK,UAAU,SAAS,CACnF,CAEO,SAASC,GAAsB,CACpC,OACE,OAAO,WAAc,cACpB,OAAO,KAAK,UAAU,SAAS,GAAM,UAAU,WAAa,YAAc,UAAU,eAAiB,EAE1G,CAEO,SAASC,GAAiB,CAC/B,OAAOF,EAAW,GAAKC,EAAW,CACpC,CAEO,SAASE,GAAoB,CAClC,OAAOJ,EAAU,GAAKG,EAAM,CAC9B,CDlBA,IAAME,EAAkB,GAkBxB,IAAMC,EAAsB,8BACfC,EAAN,cAAiCC,EAAU,QAAsB,CAKtE,aAAc,CACZ,MAAM,EALR,UAAO,YACP,YAAS,CAAC,EACV,aAA2C,KAqB3C,KAAO,MAASC,GAAyB,CAhD3C,IAAAC,EAiDI,GAAI,CAAC,KAAK,QACR,MAAM,IAAI,MAAM,0BAA0B,EAG5C,IAAMC,GAASD,EAAAD,GAAA,YAAAA,EAAQ,SAAR,KAAAC,EAAkBE,EAE3BC,EAAS,SAAS,OAElBC,EAAU,KAAK,MAAM,gDAAoE,CAC7F,CACE,KAAM,CACJ,OAAAH,EACA,OAAAE,EACA,SAAUE,EAAS,EACnB,QAAS,KAAK,OAChB,CACF,CACF,CAAC,EAEKC,EAAS,KAAK,QAA6CF,CAAO,EAExE,OAAIC,EAAS,IACX,SAAS,KAAO,KAAK,QAAQ,KAGxBC,CACT,EA3CeC,EAAA,sBACX,IAAMC,EAAO,MAAM,MAAM,GAAGZ,eAAkC,CAC5D,OAAQ,OACR,QAAS,CACP,eAAgB,kBAClB,EACA,KAAM,KAAK,UAAU,CACnB,OAAQ,SAAS,KACjB,QAAS,SAAS,MACpB,CAAC,CACH,CAAC,EAAE,KAAgCa,GAAMA,EAAE,KAAK,CAAC,EAEjD,KAAK,QAAUD,CACjB,EACF,CA8BF",
6
- "names": ["Extension", "isAndroid", "isSmallIOS", "isLargeIOS", "isIOS", "isMobile", "DEFAULT_SHOW_UI", "FARCASTER_RELAY_URL", "FarcasterExtension", "Extension", "params", "_a", "showUI", "DEFAULT_SHOW_UI", "domain", "payload", "isMobile", "handle", "__async", "json", "r"]
4
+ "sourcesContent": ["import { Extension } from '@magic-sdk/commons';\nimport { FarcasterPayloadMethod } from './types';\nimport { isMobile } from './utils';\n\nconst DEFAULT_SHOW_UI = true;\n\ntype LoginParams = {\n showUI: boolean;\n};\n\nconst FarcasterLoginEventOnReceived = {\n OpenChannel: 'channel',\n Success: 'success',\n Failed: 'failed',\n} as const;\n\ninterface CreateChannelAPIResponse {\n channelToken: string;\n url: string;\n nonce: string;\n}\n\ntype Hex = `0x${string}`;\n\ninterface StatusAPIResponse {\n state: 'pending' | 'completed';\n nonce: string;\n url: string;\n message?: string;\n signature?: `0x${string}`;\n fid?: number;\n username?: string;\n bio?: string;\n displayName?: string;\n pfpUrl?: string;\n verifications?: Hex[];\n custody?: Hex;\n}\n\ntype AuthClientErrorCode =\n | 'unauthenticated'\n | 'unauthorized'\n | 'bad_request'\n | 'bad_request.validation_failure'\n | 'not_found'\n | 'not_implemented'\n | 'unavailable'\n | 'unknown';\n\ninterface AuthClientErrorOpts {\n message: string;\n cause: Error | AuthClientError;\n presentable: boolean;\n}\n\ndeclare class AuthClientError extends Error {\n readonly errCode: AuthClientErrorCode;\n readonly presentable: boolean;\n /**\n * @param errCode - the AuthClientError code for this message\n * @param context - a message, another Error, or a AuthClientErrorOpts\n */\n constructor(errCode: AuthClientErrorCode, context: Partial<AuthClientErrorOpts> | string | Error);\n}\n\ntype FarcasterLoginEventHandlers = {\n [FarcasterLoginEventOnReceived.OpenChannel]: (channel: CreateChannelAPIResponse) => void;\n [FarcasterLoginEventOnReceived.Success]: (data: StatusAPIResponse) => void;\n [FarcasterLoginEventOnReceived.Failed]: (error: AuthClientError) => void;\n};\n\nconst FARCASTER_RELAY_URL = 'https://relay.farcaster.xyz';\nexport class FarcasterExtension extends Extension.Internal<'farcaster'> {\n name = 'farcaster' as const;\n config = {};\n channel: CreateChannelAPIResponse | null = null;\n\n constructor() {\n super();\n\n (async () => {\n const json = await fetch(`${FARCASTER_RELAY_URL}/v1/channel`, {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json',\n },\n body: JSON.stringify({\n domain: window.location.host,\n siweUri: window.location.origin,\n }),\n }).then<CreateChannelAPIResponse>((r) => r.json());\n\n this.channel = json;\n })();\n }\n\n public login = (params?: LoginParams) => {\n if (!this.channel) {\n throw new Error('Channel not created yet.');\n }\n\n const showUI = params?.showUI ?? DEFAULT_SHOW_UI;\n\n const domain = window.location.origin;\n\n const payload = this.utils.createJsonRpcRequestPayload(FarcasterPayloadMethod.FarcasterShowQR, [\n {\n data: {\n showUI,\n domain,\n isMobile: isMobile(),\n channel: this.channel,\n },\n },\n ]);\n\n const handle = this.request<string, FarcasterLoginEventHandlers>(payload);\n\n if (isMobile()) {\n window.location.href = this.channel.url;\n }\n\n return handle;\n };\n}\n", "// https://github.com/farcasterxyz/auth-monorepo/blob/main/packages/auth-kit/src/utils.ts\n\nexport function isAndroid(): boolean {\n return typeof navigator !== 'undefined' && /android/i.test(navigator.userAgent);\n}\n\nexport function isSmallIOS(): boolean {\n return typeof navigator !== 'undefined' && /iPhone|iPod/.test(navigator.userAgent);\n}\n\nexport function isLargeIOS(): boolean {\n return (\n typeof navigator !== 'undefined' &&\n (/iPad/.test(navigator.userAgent) || (navigator.platform === 'MacIntel' && navigator.maxTouchPoints > 1))\n );\n}\n\nexport function isIOS(): boolean {\n return isSmallIOS() || isLargeIOS();\n}\n\nexport function isMobile(): boolean {\n return isAndroid() || isIOS();\n}\n"],
5
+ "mappings": "6MAAA,OAAS,aAAAA,MAAiB,qBCEnB,SAASC,GAAqB,CACnC,OAAO,OAAO,WAAc,aAAe,WAAW,KAAK,UAAU,SAAS,CAChF,CAEO,SAASC,GAAsB,CACpC,OAAO,OAAO,WAAc,aAAe,cAAc,KAAK,UAAU,SAAS,CACnF,CAEO,SAASC,GAAsB,CACpC,OACE,OAAO,WAAc,cACpB,OAAO,KAAK,UAAU,SAAS,GAAM,UAAU,WAAa,YAAc,UAAU,eAAiB,EAE1G,CAEO,SAASC,GAAiB,CAC/B,OAAOF,EAAW,GAAKC,EAAW,CACpC,CAEO,SAASE,GAAoB,CAClC,OAAOJ,EAAU,GAAKG,EAAM,CAC9B,CDnBA,IAAME,EAAkB,GAmExB,IAAMC,EAAsB,8BACfC,EAAN,cAAiCC,EAAU,QAAsB,CAKtE,aAAc,CACZ,MAAM,EALR,UAAO,YACP,YAAS,CAAC,EACV,aAA2C,KAqB3C,KAAO,MAASC,GAAyB,CAhG3C,IAAAC,EAiGI,GAAI,CAAC,KAAK,QACR,MAAM,IAAI,MAAM,0BAA0B,EAG5C,IAAMC,GAASD,EAAAD,GAAA,YAAAA,EAAQ,SAAR,KAAAC,EAAkBE,EAE3BC,EAAS,OAAO,SAAS,OAEzBC,EAAU,KAAK,MAAM,gDAAoE,CAC7F,CACE,KAAM,CACJ,OAAAH,EACA,OAAAE,EACA,SAAUE,EAAS,EACnB,QAAS,KAAK,OAChB,CACF,CACF,CAAC,EAEKC,EAAS,KAAK,QAA6CF,CAAO,EAExE,OAAIC,EAAS,IACX,OAAO,SAAS,KAAO,KAAK,QAAQ,KAG/BC,CACT,EA3CeC,EAAA,sBACX,IAAMC,EAAO,MAAM,MAAM,GAAGZ,eAAkC,CAC5D,OAAQ,OACR,QAAS,CACP,eAAgB,kBAClB,EACA,KAAM,KAAK,UAAU,CACnB,OAAQ,OAAO,SAAS,KACxB,QAAS,OAAO,SAAS,MAC3B,CAAC,CACH,CAAC,EAAE,KAAgC,GAAM,EAAE,KAAK,CAAC,EAEjD,KAAK,QAAUY,CACjB,EACF,CA8BF",
6
+ "names": ["Extension", "isAndroid", "isSmallIOS", "isLargeIOS", "isIOS", "isMobile", "DEFAULT_SHOW_UI", "FARCASTER_RELAY_URL", "FarcasterExtension", "Extension", "params", "_a", "showUI", "DEFAULT_SHOW_UI", "domain", "payload", "isMobile", "handle", "__async", "json"]
7
7
  }
package/dist/extension.js CHANGED
@@ -1,2 +1,2 @@
1
- "use strict";var MagicFarcasterExtension=(()=>{var A=Object.create;var s=Object.defineProperty;var C=Object.getOwnPropertyDescriptor;var I=Object.getOwnPropertyNames;var m=Object.getPrototypeOf,y=Object.prototype.hasOwnProperty;var L=(e,n)=>()=>(n||e((n={exports:{}}).exports,n),n.exports),P=(e,n)=>{for(var t in n)s(e,t,{get:n[t],enumerable:!0})},p=(e,n,t,a)=>{if(n&&typeof n=="object"||typeof n=="function")for(let o of I(n))!y.call(e,o)&&o!==t&&s(e,o,{get:()=>n[o],enumerable:!(a=C(n,o))||a.enumerable});return e};var E=(e,n,t)=>(t=e!=null?A(m(e)):{},p(n||!e||!e.__esModule?s(t,"default",{value:e,enumerable:!0}):t,e)),O=e=>p(s({},"__esModule",{value:!0}),e);var f=(e,n,t)=>new Promise((a,o)=>{var c=r=>{try{i(t.next(r))}catch(h){o(h)}},l=r=>{try{i(t.throw(r))}catch(h){o(h)}},i=r=>r.done?a(r.value):Promise.resolve(r.value).then(c,l);i((t=t.apply(e,n)).next())});var v=L((M,g)=>{g.exports=Magic});var _={};P(_,{FarcasterExtension:()=>d});var R=E(v());function S(){return typeof navigator!="undefined"&&/android/i.test(navigator.userAgent)}function b(){return typeof navigator!="undefined"&&/iPhone|iPod/.test(navigator.userAgent)}function x(){return typeof navigator!="undefined"&&(/iPad/.test(navigator.userAgent)||navigator.platform==="MacIntel"&&navigator.maxTouchPoints>1)}function F(){return b()||x()}function u(){return S()||F()}var w=!0;var U="https://relay.farcaster.xyz",d=class extends R.Extension.Internal{constructor(){super();this.name="farcaster";this.config={};this.channel=null;this.login=t=>{var i;if(!this.channel)throw new Error("Channel not created yet.");let a=(i=t==null?void 0:t.showUI)!=null?i:w,o=location.origin,c=this.utils.createJsonRpcRequestPayload("farcaster_show_QR",[{data:{showUI:a,domain:o,isMobile:u(),channel:this.channel}}]),l=this.request(c);return u()&&(location.href=this.channel.url),l};f(this,null,function*(){let t=yield fetch(`${U}/v1/channel`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({domain:location.host,siweUri:location.origin})}).then(a=>a.json());this.channel=t})}};return O(_);})();
1
+ "use strict";var MagicFarcasterExtension=(()=>{var A=Object.create;var s=Object.defineProperty;var E=Object.getOwnPropertyDescriptor;var b=Object.getOwnPropertyNames;var m=Object.getPrototypeOf,w=Object.prototype.hasOwnProperty;var y=(e,n)=>()=>(n||e((n={exports:{}}).exports,n),n.exports),R=(e,n)=>{for(var t in n)s(e,t,{get:n[t],enumerable:!0})},g=(e,n,t,o)=>{if(n&&typeof n=="object"||typeof n=="function")for(let r of b(n))!w.call(e,r)&&r!==t&&s(e,r,{get:()=>n[r],enumerable:!(o=E(n,r))||o.enumerable});return e};var x=(e,n,t)=>(t=e!=null?A(m(e)):{},g(n||!e||!e.__esModule?s(t,"default",{value:e,enumerable:!0}):t,e)),I=e=>g(s({},"__esModule",{value:!0}),e);var p=(e,n,t)=>new Promise((o,r)=>{var l=a=>{try{i(t.next(a))}catch(u){r(u)}},c=a=>{try{i(t.throw(a))}catch(u){r(u)}},i=a=>a.done?o(a.value):Promise.resolve(a.value).then(l,c);i((t=t.apply(e,n)).next())});var C=y((T,f)=>{f.exports=Magic});var U={};R(U,{FarcasterExtension:()=>h});var v=x(C());function O(){return typeof navigator!="undefined"&&/android/i.test(navigator.userAgent)}function P(){return typeof navigator!="undefined"&&/iPhone|iPod/.test(navigator.userAgent)}function S(){return typeof navigator!="undefined"&&(/iPad/.test(navigator.userAgent)||navigator.platform==="MacIntel"&&navigator.maxTouchPoints>1)}function L(){return P()||S()}function d(){return O()||L()}var _=!0;var F="https://relay.farcaster.xyz",h=class extends v.Extension.Internal{constructor(){super();this.name="farcaster";this.config={};this.channel=null;this.login=t=>{var i;if(!this.channel)throw new Error("Channel not created yet.");let o=(i=t==null?void 0:t.showUI)!=null?i:_,r=window.location.origin,l=this.utils.createJsonRpcRequestPayload("farcaster_show_QR",[{data:{showUI:o,domain:r,isMobile:d(),channel:this.channel}}]),c=this.request(l);return d()&&(window.location.href=this.channel.url),c};p(this,null,function*(){let t=yield fetch(`${F}/v1/channel`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({domain:window.location.host,siweUri:window.location.origin})}).then(o=>o.json());this.channel=t})}};return I(U);})();
2
2
  if (MagicFarcasterExtension && MagicFarcasterExtension.default != null) { MagicFarcasterExtension = Object.assign(MagicFarcasterExtension.default, MagicFarcasterExtension); delete MagicFarcasterExtension.default; }
@@ -1,6 +1,5 @@
1
1
  import { Extension } from '@magic-sdk/commons';
2
- import type { CreateChannelAPIResponse, AuthenticateAPIResponse, AuthClientError } from '@farcaster/auth-client';
3
- type LoginParams = {
2
+ declare type LoginParams = {
4
3
  showUI: boolean;
5
4
  };
6
5
  declare const FarcasterLoginEventOnReceived: {
@@ -8,9 +7,44 @@ declare const FarcasterLoginEventOnReceived: {
8
7
  readonly Success: "success";
9
8
  readonly Failed: "failed";
10
9
  };
11
- type FarcasterLoginEventHandlers = {
10
+ interface CreateChannelAPIResponse {
11
+ channelToken: string;
12
+ url: string;
13
+ nonce: string;
14
+ }
15
+ declare type Hex = `0x${string}`;
16
+ interface StatusAPIResponse {
17
+ state: 'pending' | 'completed';
18
+ nonce: string;
19
+ url: string;
20
+ message?: string;
21
+ signature?: `0x${string}`;
22
+ fid?: number;
23
+ username?: string;
24
+ bio?: string;
25
+ displayName?: string;
26
+ pfpUrl?: string;
27
+ verifications?: Hex[];
28
+ custody?: Hex;
29
+ }
30
+ declare type AuthClientErrorCode = 'unauthenticated' | 'unauthorized' | 'bad_request' | 'bad_request.validation_failure' | 'not_found' | 'not_implemented' | 'unavailable' | 'unknown';
31
+ interface AuthClientErrorOpts {
32
+ message: string;
33
+ cause: Error | AuthClientError;
34
+ presentable: boolean;
35
+ }
36
+ declare class AuthClientError extends Error {
37
+ readonly errCode: AuthClientErrorCode;
38
+ readonly presentable: boolean;
39
+ /**
40
+ * @param errCode - the AuthClientError code for this message
41
+ * @param context - a message, another Error, or a AuthClientErrorOpts
42
+ */
43
+ constructor(errCode: AuthClientErrorCode, context: Partial<AuthClientErrorOpts> | string | Error);
44
+ }
45
+ declare type FarcasterLoginEventHandlers = {
12
46
  [FarcasterLoginEventOnReceived.OpenChannel]: (channel: CreateChannelAPIResponse) => void;
13
- [FarcasterLoginEventOnReceived.Success]: (data: AuthenticateAPIResponse) => void;
47
+ [FarcasterLoginEventOnReceived.Success]: (data: StatusAPIResponse) => void;
14
48
  [FarcasterLoginEventOnReceived.Failed]: (error: AuthClientError) => void;
15
49
  };
16
50
  export declare class FarcasterExtension extends Extension.Internal<'farcaster'> {
@@ -18,7 +52,7 @@ export declare class FarcasterExtension extends Extension.Internal<'farcaster'>
18
52
  config: {};
19
53
  channel: CreateChannelAPIResponse | null;
20
54
  constructor();
21
- login: (params?: LoginParams) => import("@magic-sdk/commons").PromiEvent<string, FarcasterLoginEventHandlers & {
55
+ login: (params?: LoginParams | undefined) => import("@magic-sdk/commons").PromiEvent<string, FarcasterLoginEventHandlers & {
22
56
  done: (result: string) => void;
23
57
  error: (reason: any) => void;
24
58
  settled: () => void;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@magic-ext/farcaster",
3
- "version": "0.0.6",
3
+ "version": "0.0.7-canary.3d5e207.0",
4
4
  "description": "magic farcaster extension",
5
5
  "author": "Magic <team@magic.link> (https://magic.link/)",
6
6
  "license": "MIT",
@@ -24,20 +24,11 @@
24
24
  },
25
25
  "externals": {
26
26
  "include": [
27
- "@magic-sdk/commons",
28
- "viem"
29
- ],
30
- "exclude": [
31
- "ethers"
27
+ "@magic-sdk/commons"
32
28
  ]
33
29
  },
34
30
  "devDependencies": {
35
31
  "@magic-sdk/commons": "^24.0.5"
36
32
  },
37
- "dependencies": {
38
- "@farcaster/auth-client": "^0.1.1",
39
- "ethers": "^6.13.0",
40
- "viem": "^2.15.1"
41
- },
42
- "gitHead": "ddb112b886940a0e18939f1bc3f289a8f13302ba"
33
+ "gitHead": "3d5e207a5754b920b446cd42e9858bda6357ecae"
43
34
  }