@opengovsg/mockpass 2.7.9

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.
Files changed (85) hide show
  1. package/.eslintrc.json +13 -0
  2. package/.gitattributes +2 -0
  3. package/.github/dependabot.yml +14 -0
  4. package/.github/mergify.yml +12 -0
  5. package/.github/workflows/ci.yml +27 -0
  6. package/.github/workflows/npmpublish.yml +22 -0
  7. package/.gitpod.yml +5 -0
  8. package/.husky/pre-commit +4 -0
  9. package/.husky/pre-push +4 -0
  10. package/.prettierrc.js +5 -0
  11. package/Dockerfile +11 -0
  12. package/LICENSE +21 -0
  13. package/README.md +99 -0
  14. package/commitlint.config.js +7 -0
  15. package/index.js +87 -0
  16. package/lib/assertions.js +319 -0
  17. package/lib/crypto/index.js +61 -0
  18. package/lib/crypto/myinfo-signature.js +153 -0
  19. package/lib/express/index.js +6 -0
  20. package/lib/express/myinfo/consent.js +160 -0
  21. package/lib/express/myinfo/controllers.js +179 -0
  22. package/lib/express/myinfo/index.js +10 -0
  23. package/lib/express/oidc.js +131 -0
  24. package/lib/express/saml.js +171 -0
  25. package/lib/express/sgid.js +168 -0
  26. package/lib/saml-artifact.js +32 -0
  27. package/package.json +81 -0
  28. package/public/mockpass/resources/css/animate.css +43 -0
  29. package/public/mockpass/resources/css/common.css +121 -0
  30. package/public/mockpass/resources/css/reset.css +95 -0
  31. package/public/mockpass/resources/css/style-baseline-small-media.css +567 -0
  32. package/public/mockpass/resources/css/style-baseline.css +1006 -0
  33. package/public/mockpass/resources/css/style-common-small-media.css +156 -0
  34. package/public/mockpass/resources/css/style-common.css +510 -0
  35. package/public/mockpass/resources/css/style-homepage-small-media.css +588 -0
  36. package/public/mockpass/resources/css/style-homepage.css +674 -0
  37. package/public/mockpass/resources/css/style-main.css +9 -0
  38. package/public/mockpass/resources/img/ajax-loader.gif +0 -0
  39. package/public/mockpass/resources/img/ask_cheryl_tab.png +0 -0
  40. package/public/mockpass/resources/img/background/large-device/sp_bg.jpg +0 -0
  41. package/public/mockpass/resources/img/background/medium-device/ipad-bg.jpg +0 -0
  42. package/public/mockpass/resources/img/background/medium-device/ipad-landscape-sp-bg.jpg +0 -0
  43. package/public/mockpass/resources/img/background/small-device/mobile-sp-bg.jpg +0 -0
  44. package/public/mockpass/resources/img/carousel/large-device/how-to-setup-2fa-icon.png +0 -0
  45. package/public/mockpass/resources/img/carousel/large-device/register-icon.png +0 -0
  46. package/public/mockpass/resources/img/carousel/large-device/reset-password-icon.png +0 -0
  47. package/public/mockpass/resources/img/carousel/large-device/setup-2fa-icon.png +0 -0
  48. package/public/mockpass/resources/img/carousel/large-device/update-acct-icon.png +0 -0
  49. package/public/mockpass/resources/img/carousel/medium-device/ipad-register-icon.png +0 -0
  50. package/public/mockpass/resources/img/carousel/medium-device/ipad-reset-password-icon.png +0 -0
  51. package/public/mockpass/resources/img/carousel/medium-device/ipad-setup-2fa-icon.png +0 -0
  52. package/public/mockpass/resources/img/carousel/medium-device/ipad-update-acct-icon.png +0 -0
  53. package/public/mockpass/resources/img/carousel/small-device/mobile-register.png +0 -0
  54. package/public/mockpass/resources/img/carousel/small-device/mobile-reset-password-icon.png +0 -0
  55. package/public/mockpass/resources/img/carousel/small-device/mobile-update-acct-icon.png +0 -0
  56. package/public/mockpass/resources/img/close.png +0 -0
  57. package/public/mockpass/resources/img/id-pw-icon.png +0 -0
  58. package/public/mockpass/resources/img/logo/mockpass-logo.png +0 -0
  59. package/public/mockpass/resources/img/logo/mockpass-placeholder-logo.png +0 -0
  60. package/public/mockpass/resources/img/logo/mockpass_watermark.png +0 -0
  61. package/public/mockpass/resources/img/qr-icon.png +0 -0
  62. package/public/mockpass/resources/img/qr-shadow.png +0 -0
  63. package/public/mockpass/resources/img/refresh.jpg +0 -0
  64. package/public/mockpass/resources/img/sidebar-icons.png +0 -0
  65. package/public/mockpass/resources/img/sp-qr-unavailable.png +0 -0
  66. package/public/mockpass/resources/img/utility-icon-black.png +0 -0
  67. package/public/mockpass/resources/js/bootstrap.min.js +7 -0
  68. package/public/mockpass/resources/js/jquery-3.5.1.js +10872 -0
  69. package/public/mockpass/resources/js/login-common.js +849 -0
  70. package/public/mockpass/resources/plugins/bootstrap-3.3.6/css/bootstrap.min.css +6 -0
  71. package/public/mockpass/resources/plugins/bootstrap-3.3.6/fonts/glyphicons-halflings-regular.woff2 +0 -0
  72. package/static/certs/csr.pem +17 -0
  73. package/static/certs/key.pem +28 -0
  74. package/static/certs/key.pub +9 -0
  75. package/static/certs/server.crt +21 -0
  76. package/static/certs/spcp-csr.pem +17 -0
  77. package/static/certs/spcp-key.pem +28 -0
  78. package/static/certs/spcp.crt +20 -0
  79. package/static/html/consent.html +40 -0
  80. package/static/html/login-page.html +271 -0
  81. package/static/myinfo/v2.json +6154 -0
  82. package/static/myinfo/v3.json +29386 -0
  83. package/static/saml/corppass.xml +21 -0
  84. package/static/saml/unsigned-assertion.xml +24 -0
  85. package/static/saml/unsigned-response.xml +19 -0
@@ -0,0 +1,21 @@
1
+ <UserInfo>
2
+ <CPUID>{{ nric }}</CPUID>
3
+ <CPEntID>{{ uen }}</CPEntID>
4
+ </UserInfo>
5
+ <AuthAccess>
6
+ <Result_Set>
7
+ <ESrvc_Row_Count>1</ESrvc_Row_Count>
8
+ <ESrvc_Result>
9
+ <CPESrvcID>SPCP-TEST</CPESrvcID>
10
+ <Auth_Result_Set>
11
+ <Row_Count>1</Row_Count>
12
+ <Row>
13
+ <CPEntID_SUB>NULL</CPEntID_SUB>
14
+ <CPRole>NULL</CPRole>
15
+ <StartDate>2018-08-13</StartDate>
16
+ <EndDate>9999-12-31</EndDate>
17
+ </Row>
18
+ </Auth_Result_Set>
19
+ </ESrvc_Result>
20
+ </Result_Set>
21
+ </AuthAccess>
@@ -0,0 +1,24 @@
1
+ <saml:Assertion xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xs="http://www.w3.org/2001/XMLSchema" ID="_d71a3a8e9fcc45c9e9d248ef7049393fc8f04e5f75" xmlns:saml="urn:oasis:names:tc:SAML:2.0:assertion" Version="2.0" IssueInstant="{{issueInstant}}">
2
+ <saml:Issuer>{{issuer}}</saml:Issuer>
3
+ <saml:Subject>
4
+ <saml:NameID Format="urn:ibm:names:ITFIM:5.1:accessmanager">{{value}}</saml:NameID>
5
+ <saml:SubjectConfirmation Method="urn:oasis:names:tc:SAML:2.0:cm:bearer">
6
+ <saml:SubjectConfirmationData NotOnOrAfter="2224-01-18T06:21:48Z" Recipient="{{recipient}}" InResponseTo="{{inResponseTo}}"/>
7
+ </saml:SubjectConfirmation>
8
+ </saml:Subject>
9
+ <saml:Conditions NotBefore="2014-07-17T01:01:18Z" NotOnOrAfter="2224-01-18T06:21:48Z">
10
+ <saml:AudienceRestriction>
11
+ <saml:Audience>{{audience}}</saml:Audience>
12
+ </saml:AudienceRestriction>
13
+ </saml:Conditions>
14
+ <saml:AuthnStatement AuthnInstant="{{issueInstant}}" SessionNotOnOrAfter="2224-07-17T09:01:48Z" SessionIndex="_be9967abd904ddcae3c0eb4189adbe3f71e327cf93">
15
+ <saml:AuthnContext>
16
+ <saml:AuthnContextClassRef>urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransport</saml:AuthnContextClassRef>
17
+ </saml:AuthnContext>
18
+ </saml:AuthnStatement>
19
+ <saml:AttributeStatement>
20
+ <saml:Attribute Name="{{name}}" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:basic">
21
+ <saml:AttributeValue xsi:type="xs:string">{{value}}</saml:AttributeValue>
22
+ </saml:Attribute>
23
+ </saml:AttributeStatement>
24
+ </saml:Assertion>
@@ -0,0 +1,19 @@
1
+ <?xml version="1.0" encoding="UTF-8"?>
2
+ <soap11:Envelope xmlns:soap11="http://schemas.xmlsoap.org/soap/envelope/">
3
+ <soap11:Body>
4
+ <samlp:ArtifactResponse xmlns:samlp="urn:oasis:names:tc:SAML:2.0:protocol"
5
+ xmlns:saml="urn:oasis:names:tc:SAML:2.0:assertion" ID="_8e8dc5f69a98cc4c1ff3427e5ce34606fd672f91e6" Version="2.0" IssueInstant="{{issueInstant}}" Destination="{{destination}}" InResponseTo="{{inResponseTo}}">
6
+ <saml:Issuer>{{issuer}}</saml:Issuer>
7
+ <samlp:Status>
8
+ <samlp:StatusCode Value="urn:oasis:names:tc:SAML:2.0:status:Success"/>
9
+ </samlp:Status>
10
+ <samlp:Response ID="_8e8dc5f69a98cc4222227e5ce34606fd672f91e6" Version="2.0" IssueInstant="{{issueInstant}}" Destination="{{destination}}">
11
+ <saml:Issuer>{{issuer}}</saml:Issuer>
12
+ <samlp:Status>
13
+ <samlp:StatusCode Value="urn:oasis:names:tc:SAML:2.0:status:Success"/>
14
+ </samlp:Status>
15
+ {{{ assertion }}}
16
+ </samlp:Response>
17
+ </samlp:ArtifactResponse>
18
+ </soap11:Body>
19
+ </soap11:Envelope>