@magic-ext/farcaster 0.18.0 → 0.18.1-canary.3013de0.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 +1 -1
- package/dist/cjs/index.js.map +3 -3
- package/dist/es/index.js +1 -1
- package/dist/es/index.js.map +3 -3
- package/dist/es/index.mjs +1 -1
- package/dist/es/index.mjs.map +3 -3
- package/dist/extension.js +1 -1
- package/dist/types/index.d.ts +5 -7
- package/package.json +3 -3
package/dist/cjs/index.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";var
|
|
1
|
+
"use strict";var i=Object.defineProperty;var g=Object.getOwnPropertyDescriptor;var p=Object.getOwnPropertyNames;var f=Object.prototype.hasOwnProperty;var h=(n,e)=>{for(var t in e)i(n,t,{get:e[t],enumerable:!0})},v=(n,e,t,o)=>{if(e&&typeof e=="object"||typeof e=="function")for(let r of p(e))!f.call(n,r)&&r!==t&&i(n,r,{get:()=>e[r],enumerable:!(o=g(e,r))||o.enumerable});return n};var C=n=>v(i({},"__esModule",{value:!0}),n);var E={};h(E,{FarcasterExtension:()=>s,isMobile:()=>a});module.exports=C(E);var u=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 b(){return typeof navigator!="undefined"&&(/iPad/.test(navigator.userAgent)||navigator.platform==="MacIntel"&&navigator.maxTouchPoints>1)}function x(){return w()||b()}function a(){return m()||x()}function c(){return typeof window!="undefined"&&window===window.top}var A=!0;var s=class extends u.Extension.Internal{constructor(){super(...arguments);this.name="farcaster";this.config={};this.login=t=>{var l;let o=this.utils.createJsonRpcRequestPayload("farcaster_show_QR",[{data:{showUI:(l=t==null?void 0:t.showUI)!=null?l:A,domain:window.location.host,siweUri:window.location.origin}}]),r=this.request(o);return r.on("channel",d=>{a()&&c()&&(window.location.href=d.url)}),r}}};
|
|
2
2
|
//# sourceMappingURL=index.js.map
|
package/dist/cjs/index.js.map
CHANGED
|
@@ -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 { FarcasterPayloadMethod } from './types';\nimport { isMainFrame, 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\
|
|
5
|
-
"mappings": "
|
|
6
|
-
"names": ["src_exports", "__export", "FarcasterExtension", "isMobile", "__toCommonJS", "import_commons", "isAndroid", "isSmallIOS", "isLargeIOS", "isIOS", "isMobile", "isMainFrame", "DEFAULT_SHOW_UI", "
|
|
4
|
+
"sourcesContent": ["import { Extension } from '@magic-sdk/commons';\nimport { FarcasterPayloadMethod } from './types';\nimport { isMainFrame, 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\nexport class FarcasterExtension extends Extension.Internal<'farcaster'> {\n name = 'farcaster' as const;\n config = {};\n\n public login = (params?: LoginParams) => {\n const payload = this.utils.createJsonRpcRequestPayload(FarcasterPayloadMethod.FarcasterShowQR, [\n {\n data: {\n showUI: params?.showUI ?? DEFAULT_SHOW_UI,\n domain: window.location.host,\n siweUri: window.location.origin,\n },\n },\n ]);\n\n const handle = this.request<string, FarcasterLoginEventHandlers>(payload);\n\n handle.on('channel', (channel: CreateChannelAPIResponse) => {\n if (isMobile() && isMainFrame()) {\n window.location.href = channel.url;\n }\n });\n\n return handle;\n };\n}\n\nexport { isMobile };\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\nexport function isMainFrame(): boolean {\n return typeof window !== 'undefined' && window === window.top;\n}\n"],
|
|
5
|
+
"mappings": "yaAAA,IAAAA,EAAA,GAAAC,EAAAD,EAAA,wBAAAE,EAAA,aAAAC,IAAA,eAAAC,EAAAJ,GAAA,IAAAK,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,CAEO,SAASE,GAAuB,CACrC,OAAO,OAAO,QAAW,aAAe,SAAW,OAAO,GAC5D,CDvBA,IAAMC,EAAkB,GAmEjB,IAAMC,EAAN,cAAiC,YAAU,QAAsB,CAAjE,kCACL,UAAO,YACP,YAAS,CAAC,EAEV,KAAO,MAASC,GAAyB,CA3E3C,IAAAC,EA4EI,IAAMC,EAAU,KAAK,MAAM,gDAAoE,CAC7F,CACE,KAAM,CACJ,QAAQD,EAAAD,GAAA,YAAAA,EAAQ,SAAR,KAAAC,EAAkBE,EAC1B,OAAQ,OAAO,SAAS,KACxB,QAAS,OAAO,SAAS,MAC3B,CACF,CACF,CAAC,EAEKC,EAAS,KAAK,QAA6CF,CAAO,EAExE,OAAAE,EAAO,GAAG,UAAYC,GAAsC,CACtDC,EAAS,GAAKC,EAAY,IAC5B,OAAO,SAAS,KAAOF,EAAQ,IAEnC,CAAC,EAEMD,CACT,EACF",
|
|
6
|
+
"names": ["src_exports", "__export", "FarcasterExtension", "isMobile", "__toCommonJS", "import_commons", "isAndroid", "isSmallIOS", "isLargeIOS", "isIOS", "isMobile", "isMainFrame", "DEFAULT_SHOW_UI", "FarcasterExtension", "params", "_a", "payload", "DEFAULT_SHOW_UI", "handle", "channel", "isMobile", "isMainFrame"]
|
|
7
7
|
}
|
package/dist/es/index.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
|
|
1
|
+
import{Extension as g}from"@magic-sdk/commons";function l(){return typeof navigator!="undefined"&&/android/i.test(navigator.userAgent)}function c(){return typeof navigator!="undefined"&&/iPhone|iPod/.test(navigator.userAgent)}function u(){return typeof navigator!="undefined"&&(/iPad/.test(navigator.userAgent)||navigator.platform==="MacIntel"&&navigator.maxTouchPoints>1)}function d(){return c()||u()}function r(){return l()||d()}function o(){return typeof window!="undefined"&&window===window.top}var p=!0;var i=class extends g.Internal{constructor(){super(...arguments);this.name="farcaster";this.config={};this.login=e=>{var t;let a=this.utils.createJsonRpcRequestPayload("farcaster_show_QR",[{data:{showUI:(t=e==null?void 0:e.showUI)!=null?t:p,domain:window.location.host,siweUri:window.location.origin}}]),n=this.request(a);return n.on("channel",s=>{r()&&o()&&(window.location.href=s.url)}),n}}};export{i as FarcasterExtension,r as isMobile};
|
|
2
2
|
//# sourceMappingURL=index.js.map
|
package/dist/es/index.js.map
CHANGED
|
@@ -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 { FarcasterPayloadMethod } from './types';\nimport { isMainFrame, 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\
|
|
5
|
-
"mappings": "
|
|
6
|
-
"names": ["Extension", "isAndroid", "isSmallIOS", "isLargeIOS", "isIOS", "isMobile", "isMainFrame", "DEFAULT_SHOW_UI", "
|
|
4
|
+
"sourcesContent": ["import { Extension } from '@magic-sdk/commons';\nimport { FarcasterPayloadMethod } from './types';\nimport { isMainFrame, 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\nexport class FarcasterExtension extends Extension.Internal<'farcaster'> {\n name = 'farcaster' as const;\n config = {};\n\n public login = (params?: LoginParams) => {\n const payload = this.utils.createJsonRpcRequestPayload(FarcasterPayloadMethod.FarcasterShowQR, [\n {\n data: {\n showUI: params?.showUI ?? DEFAULT_SHOW_UI,\n domain: window.location.host,\n siweUri: window.location.origin,\n },\n },\n ]);\n\n const handle = this.request<string, FarcasterLoginEventHandlers>(payload);\n\n handle.on('channel', (channel: CreateChannelAPIResponse) => {\n if (isMobile() && isMainFrame()) {\n window.location.href = channel.url;\n }\n });\n\n return handle;\n };\n}\n\nexport { isMobile };\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\nexport function isMainFrame(): boolean {\n return typeof window !== 'undefined' && window === window.top;\n}\n"],
|
|
5
|
+
"mappings": "AAAA,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,CAEO,SAASE,GAAuB,CACrC,OAAO,OAAO,QAAW,aAAe,SAAW,OAAO,GAC5D,CDvBA,IAAMC,EAAkB,GAmEjB,IAAMC,EAAN,cAAiCC,EAAU,QAAsB,CAAjE,kCACL,UAAO,YACP,YAAS,CAAC,EAEV,KAAO,MAASC,GAAyB,CA3E3C,IAAAC,EA4EI,IAAMC,EAAU,KAAK,MAAM,gDAAoE,CAC7F,CACE,KAAM,CACJ,QAAQD,EAAAD,GAAA,YAAAA,EAAQ,SAAR,KAAAC,EAAkBE,EAC1B,OAAQ,OAAO,SAAS,KACxB,QAAS,OAAO,SAAS,MAC3B,CACF,CACF,CAAC,EAEKC,EAAS,KAAK,QAA6CF,CAAO,EAExE,OAAAE,EAAO,GAAG,UAAYC,GAAsC,CACtDC,EAAS,GAAKC,EAAY,IAC5B,OAAO,SAAS,KAAOF,EAAQ,IAEnC,CAAC,EAEMD,CACT,EACF",
|
|
6
|
+
"names": ["Extension", "isAndroid", "isSmallIOS", "isLargeIOS", "isIOS", "isMobile", "isMainFrame", "DEFAULT_SHOW_UI", "FarcasterExtension", "Extension", "params", "_a", "payload", "DEFAULT_SHOW_UI", "handle", "channel", "isMobile", "isMainFrame"]
|
|
7
7
|
}
|
package/dist/es/index.mjs
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
|
|
1
|
+
import{Extension as g}from"@magic-sdk/commons";function l(){return typeof navigator!="undefined"&&/android/i.test(navigator.userAgent)}function c(){return typeof navigator!="undefined"&&/iPhone|iPod/.test(navigator.userAgent)}function u(){return typeof navigator!="undefined"&&(/iPad/.test(navigator.userAgent)||navigator.platform==="MacIntel"&&navigator.maxTouchPoints>1)}function d(){return c()||u()}function r(){return l()||d()}function o(){return typeof window!="undefined"&&window===window.top}var p=!0;var i=class extends g.Internal{constructor(){super(...arguments);this.name="farcaster";this.config={};this.login=e=>{var t;let a=this.utils.createJsonRpcRequestPayload("farcaster_show_QR",[{data:{showUI:(t=e==null?void 0:e.showUI)!=null?t:p,domain:window.location.host,siweUri:window.location.origin}}]),n=this.request(a);return n.on("channel",s=>{r()&&o()&&(window.location.href=s.url)}),n}}};export{i as FarcasterExtension,r as isMobile};
|
|
2
2
|
//# sourceMappingURL=index.mjs.map
|
package/dist/es/index.mjs.map
CHANGED
|
@@ -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 { FarcasterPayloadMethod } from './types';\nimport { isMainFrame, 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\
|
|
5
|
-
"mappings": "
|
|
6
|
-
"names": ["Extension", "isAndroid", "isSmallIOS", "isLargeIOS", "isIOS", "isMobile", "isMainFrame", "DEFAULT_SHOW_UI", "
|
|
4
|
+
"sourcesContent": ["import { Extension } from '@magic-sdk/commons';\nimport { FarcasterPayloadMethod } from './types';\nimport { isMainFrame, 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\nexport class FarcasterExtension extends Extension.Internal<'farcaster'> {\n name = 'farcaster' as const;\n config = {};\n\n public login = (params?: LoginParams) => {\n const payload = this.utils.createJsonRpcRequestPayload(FarcasterPayloadMethod.FarcasterShowQR, [\n {\n data: {\n showUI: params?.showUI ?? DEFAULT_SHOW_UI,\n domain: window.location.host,\n siweUri: window.location.origin,\n },\n },\n ]);\n\n const handle = this.request<string, FarcasterLoginEventHandlers>(payload);\n\n handle.on('channel', (channel: CreateChannelAPIResponse) => {\n if (isMobile() && isMainFrame()) {\n window.location.href = channel.url;\n }\n });\n\n return handle;\n };\n}\n\nexport { isMobile };\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\nexport function isMainFrame(): boolean {\n return typeof window !== 'undefined' && window === window.top;\n}\n"],
|
|
5
|
+
"mappings": "AAAA,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,CAEO,SAASE,GAAuB,CACrC,OAAO,OAAO,QAAW,aAAe,SAAW,OAAO,GAC5D,CDvBA,IAAMC,EAAkB,GAmEjB,IAAMC,EAAN,cAAiCC,EAAU,QAAsB,CAAjE,kCACL,UAAO,YACP,YAAS,CAAC,EAEV,KAAO,MAASC,GAAyB,CA3E3C,IAAAC,EA4EI,IAAMC,EAAU,KAAK,MAAM,gDAAoE,CAC7F,CACE,KAAM,CACJ,QAAQD,EAAAD,GAAA,YAAAA,EAAQ,SAAR,KAAAC,EAAkBE,EAC1B,OAAQ,OAAO,SAAS,KACxB,QAAS,OAAO,SAAS,MAC3B,CACF,CACF,CAAC,EAEKC,EAAS,KAAK,QAA6CF,CAAO,EAExE,OAAAE,EAAO,GAAG,UAAYC,GAAsC,CACtDC,EAAS,GAAKC,EAAY,IAC5B,OAAO,SAAS,KAAOF,EAAQ,IAEnC,CAAC,EAEMD,CACT,EACF",
|
|
6
|
+
"names": ["Extension", "isAndroid", "isSmallIOS", "isLargeIOS", "isIOS", "isMobile", "isMainFrame", "DEFAULT_SHOW_UI", "FarcasterExtension", "Extension", "params", "_a", "payload", "DEFAULT_SHOW_UI", "handle", "channel", "isMobile", "isMainFrame"]
|
|
7
7
|
}
|
package/dist/extension.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";var MagicFarcasterExtension=(()=>{var
|
|
1
|
+
"use strict";var MagicFarcasterExtension=(()=>{var h=Object.create;var i=Object.defineProperty;var v=Object.getOwnPropertyDescriptor;var C=Object.getOwnPropertyNames;var m=Object.getPrototypeOf,w=Object.prototype.hasOwnProperty;var b=(e,n)=>()=>(n||e((n={exports:{}}).exports,n),n.exports),x=(e,n)=>{for(var t in n)i(e,t,{get:n[t],enumerable:!0})},c=(e,n,t,o)=>{if(n&&typeof n=="object"||typeof n=="function")for(let r of C(n))!w.call(e,r)&&r!==t&&i(e,r,{get:()=>n[r],enumerable:!(o=v(n,r))||o.enumerable});return e};var A=(e,n,t)=>(t=e!=null?h(m(e)):{},c(n||!e||!e.__esModule?i(t,"default",{value:e,enumerable:!0}):t,e)),E=e=>c(i({},"__esModule",{value:!0}),e);var d=b((S,u)=>{u.exports=Magic});var P={};x(P,{FarcasterExtension:()=>s,isMobile:()=>a});var p=A(d());function I(){return typeof navigator!="undefined"&&/android/i.test(navigator.userAgent)}function R(){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 F(){return R()||y()}function a(){return I()||F()}function g(){return typeof window!="undefined"&&window===window.top}var O=!0;var s=class extends p.Extension.Internal{constructor(){super(...arguments);this.name="farcaster";this.config={};this.login=t=>{var l;let o=this.utils.createJsonRpcRequestPayload("farcaster_show_QR",[{data:{showUI:(l=t==null?void 0:t.showUI)!=null?l:O,domain:window.location.host,siweUri:window.location.origin}}]),r=this.request(o);return r.on("channel",f=>{a()&&g()&&(window.location.href=f.url)}),r}}};return E(P);})();
|
|
2
2
|
if (MagicFarcasterExtension && MagicFarcasterExtension.default != null) { MagicFarcasterExtension = Object.assign(MagicFarcasterExtension.default, MagicFarcasterExtension); delete MagicFarcasterExtension.default; }
|
package/dist/types/index.d.ts
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { Extension } from '@magic-sdk/commons';
|
|
2
2
|
import { isMobile } from './utils';
|
|
3
|
-
|
|
3
|
+
type LoginParams = {
|
|
4
4
|
showUI: boolean;
|
|
5
5
|
};
|
|
6
6
|
declare const FarcasterLoginEventOnReceived: {
|
|
@@ -13,7 +13,7 @@ interface CreateChannelAPIResponse {
|
|
|
13
13
|
url: string;
|
|
14
14
|
nonce: string;
|
|
15
15
|
}
|
|
16
|
-
|
|
16
|
+
type Hex = `0x${string}`;
|
|
17
17
|
interface StatusAPIResponse {
|
|
18
18
|
state: 'pending' | 'completed';
|
|
19
19
|
nonce: string;
|
|
@@ -28,7 +28,7 @@ interface StatusAPIResponse {
|
|
|
28
28
|
verifications?: Hex[];
|
|
29
29
|
custody?: Hex;
|
|
30
30
|
}
|
|
31
|
-
|
|
31
|
+
type AuthClientErrorCode = 'unauthenticated' | 'unauthorized' | 'bad_request' | 'bad_request.validation_failure' | 'not_found' | 'not_implemented' | 'unavailable' | 'unknown';
|
|
32
32
|
interface AuthClientErrorOpts {
|
|
33
33
|
message: string;
|
|
34
34
|
cause: Error | AuthClientError;
|
|
@@ -43,7 +43,7 @@ declare class AuthClientError extends Error {
|
|
|
43
43
|
*/
|
|
44
44
|
constructor(errCode: AuthClientErrorCode, context: Partial<AuthClientErrorOpts> | string | Error);
|
|
45
45
|
}
|
|
46
|
-
|
|
46
|
+
type FarcasterLoginEventHandlers = {
|
|
47
47
|
[FarcasterLoginEventOnReceived.OpenChannel]: (channel: CreateChannelAPIResponse) => void;
|
|
48
48
|
[FarcasterLoginEventOnReceived.Success]: (data: StatusAPIResponse) => void;
|
|
49
49
|
[FarcasterLoginEventOnReceived.Failed]: (error: AuthClientError) => void;
|
|
@@ -51,9 +51,7 @@ declare type FarcasterLoginEventHandlers = {
|
|
|
51
51
|
export declare class FarcasterExtension extends Extension.Internal<'farcaster'> {
|
|
52
52
|
name: "farcaster";
|
|
53
53
|
config: {};
|
|
54
|
-
|
|
55
|
-
constructor();
|
|
56
|
-
login: (params?: LoginParams | undefined) => import("@magic-sdk/commons").PromiEvent<string, FarcasterLoginEventHandlers & {
|
|
54
|
+
login: (params?: LoginParams) => import("@magic-sdk/commons").PromiEvent<string, FarcasterLoginEventHandlers & {
|
|
57
55
|
done: (result: string) => void;
|
|
58
56
|
error: (reason: any) => void;
|
|
59
57
|
settled: () => void;
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@magic-ext/farcaster",
|
|
3
|
-
"version": "0.18.0",
|
|
3
|
+
"version": "0.18.1-canary.3013de0.0",
|
|
4
4
|
"description": "magic farcaster extension",
|
|
5
5
|
"author": "Magic <team@magic.link> (https://magic.link/)",
|
|
6
6
|
"license": "MIT",
|
|
@@ -28,7 +28,7 @@
|
|
|
28
28
|
]
|
|
29
29
|
},
|
|
30
30
|
"devDependencies": {
|
|
31
|
-
"@magic-sdk/commons": "
|
|
31
|
+
"@magic-sdk/commons": "24.18.1-canary.3013de0.0"
|
|
32
32
|
},
|
|
33
|
-
"gitHead": "
|
|
33
|
+
"gitHead": "3013de00b44d997e38f5c951f368f8f09b67b63f"
|
|
34
34
|
}
|