@cparra/apexdocs 3.0.0 → 3.1.1

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 (264) hide show
  1. package/README.md +11 -5
  2. package/dist/cli/generate.js +1 -1
  3. package/dist/index.js +1 -1
  4. package/dist/logger-BATX7-be.js +3278 -0
  5. package/package.json +4 -1
  6. package/.github/workflows/ci.yaml +0 -22
  7. package/.github/workflows/close_stale.yml +0 -22
  8. package/.prettierrc.js +0 -7
  9. package/__mocks__/chalk.js +0 -12
  10. package/__mocks__/log-update.js +0 -6
  11. package/eslint.config.mjs +0 -10
  12. package/examples/README.md +0 -5
  13. package/examples/docsify/README.md +0 -17
  14. package/examples/docsify/apexdocs.config.ts +0 -13
  15. package/examples/docsify/classes/ASampleClass.cls +0 -57
  16. package/examples/docsify/classes/CodeControl.cls +0 -19
  17. package/examples/docsify/classes/SampleClass.cls +0 -95
  18. package/examples/docsify/classes/SampleInterface.cls +0 -17
  19. package/examples/docsify/classes/SomeDto.cls +0 -122
  20. package/examples/docsify/docs/.nojekyll +0 -0
  21. package/examples/docsify/docs/README.md +0 -25
  22. package/examples/docsify/docs/_config.yml +0 -1
  23. package/examples/docsify/docs/index.html +0 -22
  24. package/examples/docsify/docs/miscellaneous/ASampleClass.md +0 -88
  25. package/examples/docsify/docs/miscellaneous/CodeControl.md +0 -107
  26. package/examples/docsify/docs/miscellaneous/SomeDto.md +0 -244
  27. package/examples/docsify/docs/sample-classes/SampleClass.md +0 -171
  28. package/examples/docsify/docs/sample-interfaces/SampleInterface.md +0 -36
  29. package/examples/docsify/package-lock.json +0 -2459
  30. package/examples/docsify/package.json +0 -14
  31. package/examples/imported/.forceignore +0 -12
  32. package/examples/imported/README.md +0 -6
  33. package/examples/imported/config/project-scratch-def.json +0 -5
  34. package/examples/imported/docs/index.md +0 -109
  35. package/examples/imported/docs/miscellaneous/BaseClass.md +0 -13
  36. package/examples/imported/docs/miscellaneous/MultiInheritanceClass.md +0 -69
  37. package/examples/imported/docs/miscellaneous/ParentInterface.md +0 -12
  38. package/examples/imported/docs/miscellaneous/ReferencedEnum.md +0 -5
  39. package/examples/imported/docs/miscellaneous/SampleException.md +0 -21
  40. package/examples/imported/docs/miscellaneous/SampleInterface.md +0 -113
  41. package/examples/imported/docs/miscellaneous/Url.md +0 -308
  42. package/examples/imported/docs/sample-enums/SampleEnum.md +0 -33
  43. package/examples/imported/docs/samplegroup/SampleClass.md +0 -167
  44. package/examples/imported/force-app/classes/BaseClass.cls +0 -3
  45. package/examples/imported/force-app/classes/MultiInheritanceClass.cls +0 -1
  46. package/examples/imported/force-app/classes/ParentInterface.cls +0 -3
  47. package/examples/imported/force-app/classes/ReferencedEnum.cls +0 -3
  48. package/examples/imported/force-app/classes/SampleClass.cls +0 -72
  49. package/examples/imported/force-app/classes/SampleEnum.cls +0 -30
  50. package/examples/imported/force-app/classes/SampleException.cls +0 -17
  51. package/examples/imported/force-app/classes/SampleInterface.cls +0 -50
  52. package/examples/imported/force-app/classes/Url.cls +0 -196
  53. package/examples/imported/package-lock.json +0 -665
  54. package/examples/imported/package.json +0 -6
  55. package/examples/imported/scripts/process-docs.mjs +0 -16
  56. package/examples/imported/sfdx-project.json +0 -12
  57. package/examples/markdown/.forceignore +0 -12
  58. package/examples/markdown/README.md +0 -7
  59. package/examples/markdown/config/project-scratch-def.json +0 -5
  60. package/examples/markdown/docs/index.md +0 -109
  61. package/examples/markdown/docs/miscellaneous/BaseClass.md +0 -16
  62. package/examples/markdown/docs/miscellaneous/MultiInheritanceClass.md +0 -72
  63. package/examples/markdown/docs/miscellaneous/ParentInterface.md +0 -15
  64. package/examples/markdown/docs/miscellaneous/ReferencedEnum.md +0 -8
  65. package/examples/markdown/docs/miscellaneous/SampleException.md +0 -24
  66. package/examples/markdown/docs/miscellaneous/SampleInterface.md +0 -116
  67. package/examples/markdown/docs/miscellaneous/Url.md +0 -311
  68. package/examples/markdown/docs/sample-enums/SampleEnum.md +0 -36
  69. package/examples/markdown/docs/samplegroup/SampleClass.md +0 -170
  70. package/examples/markdown/force-app/classes/BaseClass.cls +0 -3
  71. package/examples/markdown/force-app/classes/MultiInheritanceClass.cls +0 -1
  72. package/examples/markdown/force-app/classes/ParentInterface.cls +0 -3
  73. package/examples/markdown/force-app/classes/ReferencedEnum.cls +0 -3
  74. package/examples/markdown/force-app/classes/SampleClass.cls +0 -72
  75. package/examples/markdown/force-app/classes/SampleEnum.cls +0 -30
  76. package/examples/markdown/force-app/classes/SampleException.cls +0 -17
  77. package/examples/markdown/force-app/classes/SampleInterface.cls +0 -50
  78. package/examples/markdown/force-app/classes/Url.cls +0 -196
  79. package/examples/markdown/package-lock.json +0 -665
  80. package/examples/markdown/package.json +0 -20
  81. package/examples/markdown/sfdx-project.json +0 -12
  82. package/examples/markdown-jsconfig/.forceignore +0 -12
  83. package/examples/markdown-jsconfig/README.md +0 -9
  84. package/examples/markdown-jsconfig/apexdocs.config.mjs +0 -22
  85. package/examples/markdown-jsconfig/config/project-scratch-def.json +0 -5
  86. package/examples/markdown-jsconfig/docs/index.md +0 -12
  87. package/examples/markdown-jsconfig/docs/miscellaneous/Url.md +0 -315
  88. package/examples/markdown-jsconfig/force-app/classes/Url.cls +0 -196
  89. package/examples/markdown-jsconfig/package-lock.json +0 -665
  90. package/examples/markdown-jsconfig/package.json +0 -15
  91. package/examples/markdown-jsconfig/sfdx-project.json +0 -12
  92. package/examples/open-api/README.md +0 -5
  93. package/examples/open-api/config/project-scratch-def.json +0 -13
  94. package/examples/open-api/docs/openapi.json +0 -14
  95. package/examples/open-api/force-app/main/default/classes/ChildClass.cls +0 -42
  96. package/examples/open-api/force-app/main/default/classes/SampleClass.cls +0 -167
  97. package/examples/open-api/force-app/main/default/restapi/SampleRestResource.cls +0 -195
  98. package/examples/open-api/force-app/main/default/restapi/SampleRestResourceToSkip.cls +0 -35
  99. package/examples/open-api/force-app/main/default/restapi/SampleRestResourceWithInnerClass.cls +0 -24
  100. package/examples/open-api/force-app/main/default/restapi/SampleRestResourceWithoutApexDocs.cls +0 -15
  101. package/examples/open-api/force-app/main/default/restapi/references/Reference1.cls +0 -9
  102. package/examples/open-api/force-app/main/default/restapi/references/Reference2.cls +0 -9
  103. package/examples/open-api/force-app/main/default/restapi/references/Reference3.cls +0 -3
  104. package/examples/open-api/force-app/main/default/restapi/references/Reference4.cls +0 -3
  105. package/examples/open-api/force-app/main/default/restapi/references/Reference5.cls +0 -3
  106. package/examples/open-api/force-app/main/default/restapi/references/Reference6.cls +0 -6
  107. package/examples/open-api/force-app/main/default/restapi/references/Reference7.cls +0 -3
  108. package/examples/open-api/package-lock.json +0 -724
  109. package/examples/open-api/package.json +0 -20
  110. package/examples/open-api/sfdx-project.json +0 -12
  111. package/examples/vitepress/.forceignore +0 -12
  112. package/examples/vitepress/README.md +0 -25
  113. package/examples/vitepress/apexdocs.config.ts +0 -113
  114. package/examples/vitepress/config/project-scratch-def.json +0 -13
  115. package/examples/vitepress/docs/.vitepress/cache/deps/@theme_index.js +0 -259
  116. package/examples/vitepress/docs/.vitepress/cache/deps/@theme_index.js.map +0 -7
  117. package/examples/vitepress/docs/.vitepress/cache/deps/_metadata.json +0 -40
  118. package/examples/vitepress/docs/.vitepress/cache/deps/chunk-574YRH25.js +0 -11474
  119. package/examples/vitepress/docs/.vitepress/cache/deps/chunk-574YRH25.js.map +0 -7
  120. package/examples/vitepress/docs/.vitepress/cache/deps/chunk-E5DZZB2I.js +0 -9172
  121. package/examples/vitepress/docs/.vitepress/cache/deps/chunk-E5DZZB2I.js.map +0 -7
  122. package/examples/vitepress/docs/.vitepress/cache/deps/package.json +0 -3
  123. package/examples/vitepress/docs/.vitepress/cache/deps/vitepress___@vue_devtools-api.js +0 -4339
  124. package/examples/vitepress/docs/.vitepress/cache/deps/vitepress___@vue_devtools-api.js.map +0 -7
  125. package/examples/vitepress/docs/.vitepress/cache/deps/vitepress___@vueuse_core.js +0 -567
  126. package/examples/vitepress/docs/.vitepress/cache/deps/vitepress___@vueuse_core.js.map +0 -7
  127. package/examples/vitepress/docs/.vitepress/cache/deps/vue.js +0 -323
  128. package/examples/vitepress/docs/.vitepress/cache/deps/vue.js.map +0 -7
  129. package/examples/vitepress/docs/.vitepress/config.mts +0 -21
  130. package/examples/vitepress/docs/.vitepress/sidebar.json +0 -119
  131. package/examples/vitepress/docs/api-examples.md +0 -49
  132. package/examples/vitepress/docs/index-frontmatter.md +0 -16
  133. package/examples/vitepress/docs/index.md +0 -56
  134. package/examples/vitepress/docs/markdown-examples.md +0 -85
  135. package/examples/vitepress/docs/miscellaneous/BaseClass.md +0 -20
  136. package/examples/vitepress/docs/miscellaneous/MultiInheritanceClass.md +0 -76
  137. package/examples/vitepress/docs/miscellaneous/ParentInterface.md +0 -19
  138. package/examples/vitepress/docs/miscellaneous/ReferencedEnum.md +0 -15
  139. package/examples/vitepress/docs/miscellaneous/SampleException.md +0 -28
  140. package/examples/vitepress/docs/miscellaneous/SampleInterface.md +0 -116
  141. package/examples/vitepress/docs/miscellaneous/Url.md +0 -317
  142. package/examples/vitepress/docs/sample-enums/SampleEnum.md +0 -40
  143. package/examples/vitepress/docs/samplegroup/SampleClass.md +0 -174
  144. package/examples/vitepress/force-app/main/default/classes/BaseClass.cls +0 -3
  145. package/examples/vitepress/force-app/main/default/classes/MultiInheritanceClass.cls +0 -1
  146. package/examples/vitepress/force-app/main/default/classes/ParentInterface.cls +0 -3
  147. package/examples/vitepress/force-app/main/default/classes/ReferencedEnum.cls +0 -5
  148. package/examples/vitepress/force-app/main/default/classes/Url.cls +0 -198
  149. package/examples/vitepress/force-app/main/default/classes/feature-a/SampleClass.cls +0 -73
  150. package/examples/vitepress/force-app/main/default/classes/feature-a/SampleEnum.cls +0 -30
  151. package/examples/vitepress/force-app/main/default/classes/feature-a/SampleException.cls +0 -17
  152. package/examples/vitepress/force-app/main/default/classes/feature-a/SampleInterface.cls +0 -46
  153. package/examples/vitepress/package-lock.json +0 -2574
  154. package/examples/vitepress/package.json +0 -18
  155. package/examples/vitepress/sfdx-project.json +0 -12
  156. package/jest.config.js +0 -10
  157. package/jest.d.ts +0 -7
  158. package/src/application/Apexdocs.ts +0 -69
  159. package/src/application/__tests__/apex-file-reader.spec.ts +0 -128
  160. package/src/application/apex-file-reader.ts +0 -56
  161. package/src/application/file-system.ts +0 -69
  162. package/src/application/file-writer.ts +0 -43
  163. package/src/application/generators/markdown.ts +0 -45
  164. package/src/application/generators/openapi.ts +0 -75
  165. package/src/cli/args.ts +0 -55
  166. package/src/cli/commands/markdown.ts +0 -56
  167. package/src/cli/commands/openapi.ts +0 -36
  168. package/src/cli/generate.ts +0 -32
  169. package/src/core/__test__/manifest.spec.ts +0 -16
  170. package/src/core/manifest.ts +0 -90
  171. package/src/core/markdown/__test__/expect-extensions.ts +0 -32
  172. package/src/core/markdown/__test__/generating-class-docs.spec.ts +0 -362
  173. package/src/core/markdown/__test__/generating-docs.spec.ts +0 -378
  174. package/src/core/markdown/__test__/generating-enum-docs.spec.ts +0 -61
  175. package/src/core/markdown/__test__/generating-interface-docs.spec.ts +0 -169
  176. package/src/core/markdown/__test__/generating-reference-guide.spec.ts +0 -196
  177. package/src/core/markdown/__test__/inheritance-chain.test.ts +0 -54
  178. package/src/core/markdown/__test__/test-helpers.ts +0 -25
  179. package/src/core/markdown/adapters/__tests__/documentables.spec.ts +0 -109
  180. package/src/core/markdown/adapters/__tests__/interface-adapter.spec.ts +0 -150
  181. package/src/core/markdown/adapters/__tests__/link-generator.spec.ts +0 -130
  182. package/src/core/markdown/adapters/__tests__/references.spec.ts +0 -136
  183. package/src/core/markdown/adapters/apex-types.ts +0 -238
  184. package/src/core/markdown/adapters/documentables.ts +0 -115
  185. package/src/core/markdown/adapters/fields-and-properties.ts +0 -45
  186. package/src/core/markdown/adapters/generate-link.ts +0 -82
  187. package/src/core/markdown/adapters/inline.ts +0 -143
  188. package/src/core/markdown/adapters/methods-and-constructors.ts +0 -133
  189. package/src/core/markdown/adapters/reference-guide.ts +0 -37
  190. package/src/core/markdown/adapters/renderable-bundle.ts +0 -61
  191. package/src/core/markdown/adapters/renderable-to-page-data.ts +0 -91
  192. package/src/core/markdown/adapters/type-utils.ts +0 -13
  193. package/src/core/markdown/adapters/types.d.ts +0 -180
  194. package/src/core/markdown/generate-docs.ts +0 -210
  195. package/src/core/markdown/reflection/__test__/filter-scope.spec.ts +0 -290
  196. package/src/core/markdown/reflection/__test__/helpers.ts +0 -18
  197. package/src/core/markdown/reflection/__test__/remove-excluded-tags.spec.ts +0 -200
  198. package/src/core/markdown/reflection/filter-scope.ts +0 -13
  199. package/src/core/markdown/reflection/inheritance-chain-expanion.ts +0 -22
  200. package/src/core/markdown/reflection/inheritance-chain.ts +0 -23
  201. package/src/core/markdown/reflection/inherited-member-expansion.ts +0 -105
  202. package/src/core/markdown/reflection/reflect-source.ts +0 -123
  203. package/src/core/markdown/reflection/remove-excluded-tags.ts +0 -168
  204. package/src/core/markdown/reflection/sort-types-and-members.ts +0 -61
  205. package/src/core/markdown/templates/class-template.ts +0 -75
  206. package/src/core/markdown/templates/constructors-partial-template.ts +0 -32
  207. package/src/core/markdown/templates/documentable-partial-template.ts +0 -26
  208. package/src/core/markdown/templates/enum-template.ts +0 -12
  209. package/src/core/markdown/templates/fieldsPartialTemplate.ts +0 -23
  210. package/src/core/markdown/templates/grouped-members-partial-template.ts +0 -6
  211. package/src/core/markdown/templates/hookable.ts +0 -7
  212. package/src/core/markdown/templates/interface-template.ts +0 -16
  213. package/src/core/markdown/templates/methods-partial-template.ts +0 -43
  214. package/src/core/markdown/templates/reference-guide.ts +0 -14
  215. package/src/core/markdown/templates/template.ts +0 -114
  216. package/src/core/markdown/templates/type-doc-partial.ts +0 -27
  217. package/src/core/markdown/utils.ts +0 -3
  218. package/src/core/openApiSettings.ts +0 -41
  219. package/src/core/openapi/__tests__/manifest-factory.spec.ts +0 -16
  220. package/src/core/openapi/__tests__/open-api-docs-processor.spec.ts +0 -59
  221. package/src/core/openapi/__tests__/open-api.spec.ts +0 -22
  222. package/src/core/openapi/apex-doc-types.ts +0 -26
  223. package/src/core/openapi/apex-type-wrappers/ClassMirrorWrapper.ts +0 -12
  224. package/src/core/openapi/apex-type-wrappers/MethodMirrorWrapper.ts +0 -11
  225. package/src/core/openapi/apex-type-wrappers/__tests__/ClassMirrorWrapper.spec.ts +0 -15
  226. package/src/core/openapi/file-container.ts +0 -13
  227. package/src/core/openapi/manifest-factory.ts +0 -16
  228. package/src/core/openapi/open-api-docs-processor.ts +0 -93
  229. package/src/core/openapi/open-api-types.ts +0 -119
  230. package/src/core/openapi/open-api.ts +0 -45
  231. package/src/core/openapi/openapi-type-file.ts +0 -12
  232. package/src/core/openapi/parser.ts +0 -163
  233. package/src/core/openapi/parsers/Builder.ts +0 -40
  234. package/src/core/openapi/parsers/MethodParser.ts +0 -249
  235. package/src/core/openapi/parsers/ParameterObjectBuilder.ts +0 -13
  236. package/src/core/openapi/parsers/ReferenceBuilder.ts +0 -299
  237. package/src/core/openapi/parsers/RequestBodyBuilder.ts +0 -19
  238. package/src/core/openapi/parsers/ResponsesBuilder.ts +0 -21
  239. package/src/core/openapi/parsers/__tests__/MethodParser.spec.ts +0 -44
  240. package/src/core/openapi/parsers/__tests__/ParameterObjectBuilder.spec.ts +0 -68
  241. package/src/core/openapi/parsers/__tests__/ReferenceBuilder.spec.ts +0 -751
  242. package/src/core/openapi/parsers/__tests__/RequestBodyBuilder.spec.ts +0 -64
  243. package/src/core/openapi/parsers/__tests__/ResponsesBuilder.spec.ts +0 -55
  244. package/src/core/openapi/transpiler.ts +0 -17
  245. package/src/core/openapi/types-repository.ts +0 -54
  246. package/src/core/parse-apex-metadata.ts +0 -30
  247. package/src/core/shared/types.d.ts +0 -150
  248. package/src/core/shared/utils.ts +0 -5
  249. package/src/defaults.ts +0 -21
  250. package/src/index.ts +0 -110
  251. package/src/test-helpers/AnnotationBuilder.ts +0 -29
  252. package/src/test-helpers/ClassMirrorBuilder.ts +0 -69
  253. package/src/test-helpers/DocCommentAnnotationBuilder.ts +0 -24
  254. package/src/test-helpers/DocCommentBuilder.ts +0 -36
  255. package/src/test-helpers/FieldMirrorBuilder.ts +0 -59
  256. package/src/test-helpers/InterfaceMirrorBuilder.ts +0 -39
  257. package/src/test-helpers/MethodMirrorBuilder.ts +0 -77
  258. package/src/test-helpers/SettingsBuilder.ts +0 -17
  259. package/src/util/error-logger.ts +0 -92
  260. package/src/util/fp.ts +0 -3
  261. package/src/util/logger.ts +0 -51
  262. package/src/util/string-utils.ts +0 -7
  263. package/tsconfig.json +0 -25
  264. package/tslint.json +0 -6
@@ -1,20 +0,0 @@
1
- {
2
- "name": "plain-markdown",
3
- "scripts": {
4
- "docs:clean": "rimraf docs",
5
- "docs:build": "ts-node ../../src/cli/generate.ts markdown",
6
- "docs:help": "ts-node ../../src/cli/generate.ts markdown --help",
7
- "docs:gen": "npm run docs:clean && npm run docs:build"
8
- },
9
- "devDependencies": {
10
- "ts-node": "^10.9.2"
11
- },
12
- "dependencies": {
13
- "rimraf": "^5.0.7"
14
- },
15
- "apexdocs": {
16
- "sourceDir": "force-app",
17
- "scope": ["global", "public", "protected", "private", "namespaceaccessible"],
18
- "namespace": "ns"
19
- }
20
- }
@@ -1,12 +0,0 @@
1
- {
2
- "packageDirectories": [
3
- {
4
- "path": "force-app",
5
- "default": true
6
- }
7
- ],
8
- "name": "plain-markdown",
9
- "namespace": "",
10
- "sfdcLoginUrl": "https://login.salesforce.com",
11
- "sourceApiVersion": "59.0"
12
- }
@@ -1,12 +0,0 @@
1
- # List files or directories below to ignore them when running force:source:push, force:source:pull, and force:source:status
2
- # More information: https://developer.salesforce.com/docs/atlas.en-us.sfdx_dev.meta/sfdx_dev/sfdx_dev_exclude_source.htm
3
- #
4
-
5
- package.xml
6
-
7
- # LWC configuration files
8
- **/jsconfig.json
9
- **/.eslintrc.json
10
-
11
- # LWC Jest
12
- **/__tests__/**
@@ -1,9 +0,0 @@
1
- # Markdown with JS Config Example
2
-
3
- This project contains an example for generating simple markdown documentation.
4
-
5
- It has no integrations with a Static Site Generator (SSG) or any other tool.
6
-
7
- The configuration is powered by a JavaScript file, `apexdocs.config.js`. In it you will
8
- find it uses a few of the configuration hooks that are available, which allow you to customize
9
- the output of the documentation.
@@ -1,22 +0,0 @@
1
- import { defineMarkdownConfig } from '../../dist/index.js';
2
-
3
- export default defineMarkdownConfig({
4
- sourceDir: 'force-app',
5
- scope: ['global', 'public', 'protected', 'private', 'namespaceaccessible'],
6
- namespace: 'ns',
7
- referenceGuideTitle: 'Custom Title',
8
- transformReferenceGuide: () => {
9
- return {
10
- frontmatter: {
11
- title: 'ApexDocs Reference Guide',
12
- },
13
- };
14
- },
15
- transformDocPage: (page) => {
16
- return {
17
- frontmatter: {
18
- title: page.source.name,
19
- },
20
- };
21
- },
22
- });
@@ -1,5 +0,0 @@
1
- {
2
- "orgName": "cesarparra company",
3
- "edition": "Developer",
4
- "features": []
5
- }
@@ -1,12 +0,0 @@
1
- ---
2
- title: ApexDocs Reference Guide
3
- ---
4
-
5
- # Custom Title
6
-
7
- ## Miscellaneous
8
-
9
- ### [Url](miscellaneous/Url.md)
10
-
11
- Represents a uniform resource locator (URL) and provides access to parts of the URL.
12
- Enables access to the base URL used to access your Salesforce org.
@@ -1,315 +0,0 @@
1
- ---
2
- title: Url
3
- ---
4
-
5
- # Url Class
6
-
7
- Represents a uniform resource locator (URL) and provides access to parts of the URL.
8
- Enables access to the base URL used to access your Salesforce org.
9
-
10
- **Usage**
11
-
12
- Use the methods of the `System.URL` class to create links to objects in your organization. Such objects can be files, images,
13
- logos, or records that you want to include in external emails, in activities, or in Chatter posts. For example, you can create
14
- a link to a file uploaded as an attachment to a Chatter post by concatenating the Salesforce base URL with the file ID:
15
-
16
- ```apex
17
- // Get a file uploaded through Chatter.
18
- ContentDocument doc = [SELECT Id FROM ContentDocument
19
- WHERE Title = 'myfile'];
20
- // Create a link to the file.
21
- String fullFileURL = URL.getOrgDomainURL().toExternalForm() +
22
- '/' + doc.id;
23
- system.debug(fullFileURL);
24
- ```
25
-
26
-
27
- The following example creates a link to a Salesforce record. The full URL is created by concatenating the Salesforce base
28
- URL with the record ID.
29
-
30
- ```apex
31
- Account acct = [SELECT Id FROM Account WHERE Name = 'Acme' LIMIT 1];
32
- String fullRecordURL = URL.getOrgDomainURL().toExternalForm() + '/' + acct.Id;
33
- ```
34
-
35
- **Version Behavior Changes**
36
-
37
- In API version 41.0 and later, Apex URL objects are represented by the java.net.URI type, not the java.net.URL type.
38
- The API version in which the URL object was instantiated determines the behavior of subsequent method calls to the
39
- specific instance. Salesforce strongly encourages you to use API 41.0 and later versions for fully RFC-compliant URL
40
- parsing that includes proper handling of edge cases of complex URL structures. API 41.0 and later versions also enforce
41
- that inputs are valid, RFC-compliant URL or URI strings.
42
-
43
- * [URL Constructors](https://developer.salesforce.com/docs/atlas.en-us.apexref.meta/apexref/apex_methods_system_url.htm#apex_System_URL_constructors)
44
- * [URL Methods](https://developer.salesforce.com/docs/atlas.en-us.apexref.meta/apexref/apex_methods_system_url.htm#apex_System_URL_methods)
45
-
46
- **See Also**
47
- * [URL Class](https://developer.salesforce.com/docs/atlas.en-us.apexcode.meta/apexcode/apex_classes_url.htm)
48
-
49
- ## Namespace
50
- ns
51
-
52
- ## Example
53
- In this example, the base URL and the full request URL of the current Salesforce server instance are retrieved. Next, a URL
54
- pointing to a specific account object is created. Finally, components of the base and full URL are obtained. This example
55
- prints out all the results to the debug log output.
56
-
57
- ```apex
58
- // Create a new account called Acme that we will create a link for later.
59
- Account myAccount = new Account(Name='Acme');
60
- insert myAccount;
61
-
62
- // Get the base URL.
63
- String sfdcBaseURL = URL.getOrgDomainURL().toExternalForm();
64
- System.debug('Base URL: ' + sfdcBaseURL );
65
-
66
- // Get the URL for the current request.
67
- String currentRequestURL = URL.getCurrentRequestUrl().toExternalForm();
68
- System.debug('Current request URL: ' + currentRequestURL);
69
-
70
- // Create the account URL from the base URL.
71
- String accountURL = URL.getOrgDomainURL().toExternalForm() +
72
- '/' + myAccount.Id;
73
- System.debug('URL of a particular account: ' + accountURL);
74
-
75
- // Get some parts of the base URL.
76
- System.debug('Host: ' + URL.getOrgDomainURL().getHost());
77
- System.debug('Protocol: ' + URL.getOrgDomainURL().getProtocol());
78
-
79
- // Get the query string of the current request.
80
- System.debug('Query: ' + URL.getCurrentRequestUrl().getQuery());
81
- ```
82
-
83
- ## Constructors
84
- ### `Url(spec)`
85
-
86
- Creates a new instance of the URL class using the specified string representation of the URL.
87
-
88
- #### Signature
89
- ```apex
90
- global Url(String spec)
91
- ```
92
-
93
- #### Parameters
94
- | Name | Type | Description |
95
- |------|------|-------------|
96
- | spec | String | The string to parse as a URL. |
97
-
98
- ---
99
-
100
- ### `Url(context, spec)`
101
-
102
- Creates a new instance of the URL class by parsing the specified spec within the specified context.
103
-
104
- **Usage**
105
-
106
- The new URL is created from the given context URL and the spec argument as described in RFC2396 "Uniform Resource Identifiers : Generic * Syntax" :
107
- ```xml
108
- <scheme>://<authority><path>?<query>#<fragment>
109
- ```
110
-
111
-
112
- For more information about the arguments of this constructor, see the corresponding URL(java.net.URL, java.lang.String) constructor for Java.
113
-
114
- #### Signature
115
- ```apex
116
- global Url(Url context, String spec)
117
- ```
118
-
119
- #### Parameters
120
- | Name | Type | Description |
121
- |------|------|-------------|
122
- | context | [Url](Url.md) | The context in which to parse the specification. |
123
- | spec | String | The string to parse as a URL. |
124
-
125
- ---
126
-
127
- ### `Url(protocol, host, file)`
128
-
129
- Creates a new instance of the URL class using the specified protocol, host, and file on the host. The default port for the specified protocol is used.
130
-
131
- #### Signature
132
- ```apex
133
- global Url(String protocol, String host, String file)
134
- ```
135
-
136
- #### Parameters
137
- | Name | Type | Description |
138
- |------|------|-------------|
139
- | protocol | String | The protocol name for this URL. |
140
- | host | String | The host name for this URL. |
141
- | file | String | The file name for this URL. |
142
-
143
- ---
144
-
145
- ### `Url(protocol, host, port, file)`
146
-
147
- Creates a new instance of the URL class using the specified protocol, host, port number, and file on the host.
148
-
149
- #### Signature
150
- ```apex
151
- global Url(String protocol, String host, Integer port, String file)
152
- ```
153
-
154
- #### Parameters
155
- | Name | Type | Description |
156
- |------|------|-------------|
157
- | protocol | String | The protocol name for this URL. |
158
- | host | String | The host name for this URL. |
159
- | port | Integer | The port number for this URL. |
160
- | file | String | The file name for this URL. |
161
-
162
- ## Methods
163
- ### `getAuthority()`
164
-
165
- Returns the authority portion of the current URL.
166
-
167
- #### Signature
168
- ```apex
169
- global String getAuthority()
170
- ```
171
-
172
- #### Return Type
173
- **String**
174
-
175
- The authority portion of the current URL.
176
-
177
- ---
178
-
179
- ### `getCurrentRequestUrl()`
180
-
181
- Returns the URL of an entire request on a Salesforce instance.
182
-
183
- **Usage**
184
-
185
- An example of a URL for an entire request is https://yourInstance.salesforce.com/apex/myVfPage.apexp.
186
-
187
- #### Signature
188
- ```apex
189
- global static Url getCurrentRequestUrl()
190
- ```
191
-
192
- #### Return Type
193
- **[Url](Url.md)**
194
-
195
- The URL of the entire request.
196
-
197
- ---
198
-
199
- ### `getDefPort()`
200
-
201
- Returns the default port number of the protocol associated with the current URL.
202
-
203
- **Usage**
204
-
205
- Returns -1 if the URL scheme or the stream protocol handler for the URL doesn&#x27;t define a default port number.
206
-
207
- #### Signature
208
- ```apex
209
- global Integer getDefPort()
210
- ```
211
-
212
- #### Return Type
213
- **Integer**
214
-
215
- The default port number of the protocol associated with the current URL.
216
-
217
- ---
218
-
219
- ### `getFile()`
220
-
221
- Returns the file name of the current URL.
222
-
223
- #### Signature
224
- ```apex
225
- global String getFile()
226
- ```
227
-
228
- #### Return Type
229
- **String**
230
-
231
- The file name of the current URL.
232
-
233
- ---
234
-
235
- ### `getFileFieldURL(entityId, fieldName)`
236
-
237
- Returns the download URL for a file attachment.
238
-
239
- #### Signature
240
- ```apex
241
- global static String getFileFieldURL(String entityId, String fieldName)
242
- ```
243
-
244
- #### Parameters
245
- | Name | Type | Description |
246
- |------|------|-------------|
247
- | entityId | String | Specifies the ID of the entity that holds the file data. |
248
- | fieldName | String | Specifies the API name of a file field component, such as `AttachmentBody` . |
249
-
250
- #### Return Type
251
- **String**
252
-
253
- The download URL for the file attachment.
254
-
255
- #### Example
256
- String fileURL &#x3D;
257
- URL.getFileFieldURL(
258
- &#x27;087000000000123&#x27; ,
259
- &#x27;AttachmentBody&#x27;);
260
-
261
- ---
262
-
263
- ### `getHost()`
264
-
265
- Returns the host name of the current URL.
266
-
267
- #### Signature
268
- ```apex
269
- global String getHost()
270
- ```
271
-
272
- #### Return Type
273
- **String**
274
-
275
- The host name of the current URL.
276
-
277
- ---
278
-
279
- ### `getOrgDomainUrl()`
280
-
281
- Returns the canonical URL for your org. For example, https://MyDomainName.my.salesforce.com.
282
-
283
- **Usage**
284
-
285
- Use getOrgDomainUrl() to interact with Salesforce REST and SOAP APIs in Apex code. Get endpoints for User Interface API calls, for creating and customizing picklist value sets and custom fields, and more.
286
-
287
- `getOrgDomainUrl()` can access the domain URL only for the org in which the Apex code is running.
288
-
289
- You don&#x27;t need a RemoteSiteSetting for your org to interact with the Salesforce APIs using domain URLs retrieved with this method.
290
-
291
- **See Also**
292
-
293
- * [Lightning Aura Components Developer Guide: Making API Calls from Apex](https://developer.salesforce.com/docs/atlas.en-us.250.0.lightning.meta/lightning/apex_api_calls.htm)
294
-
295
- #### Signature
296
- ```apex
297
- global static Url getOrgDomainUrl()
298
- ```
299
-
300
- #### Return Type
301
- **[Url](Url.md)**
302
-
303
- getOrgDomainUrl() always returns the login URL for your org, regardless of context. Use that URL when making API calls to your org.
304
-
305
- #### Example
306
- This example uses the Salesforce REST API to get organization limit values. For information on limits, see Limits in the REST API Developer Guide.
307
- ```apex
308
- Http h = new Http();
309
- HttpRequest req = new HttpRequest();
310
- req.setEndpoint(Url.getOrgDomainUrl().toExternalForm()
311
- + '/services/data/v44.0/limits');
312
- req.setMethod('GET');
313
- req.setHeader('Authorization', 'Bearer ' + UserInfo.getSessionId());
314
- HttpResponse res = h.send(req);
315
- ```
@@ -1,196 +0,0 @@
1
- /**
2
- * @description Represents a uniform resource locator (URL) and provides access to parts of the URL.
3
- * Enables access to the base URL used to access your Salesforce org.
4
- *
5
- * @usage
6
- * Use the methods of the `System.URL` class to create links to objects in your organization. Such objects can be files, images,
7
- * logos, or records that you want to include in external emails, in activities, or in Chatter posts. For example, you can create
8
- * a link to a file uploaded as an attachment to a Chatter post by concatenating the Salesforce base URL with the file ID:
9
- *
10
- * ```apex
11
- * // Get a file uploaded through Chatter.
12
- * ContentDocument doc = [SELECT Id FROM ContentDocument
13
- * WHERE Title = 'myfile'];
14
- * // Create a link to the file.
15
- * String fullFileURL = URL.getOrgDomainURL().toExternalForm() +
16
- * '/' + doc.id;
17
- * system.debug(fullFileURL);
18
- * ```
19
- *
20
- * The following example creates a link to a Salesforce record. The full URL is created by concatenating the Salesforce base
21
- * URL with the record ID.
22
- *
23
- * ```apex
24
- * Account acct = [SELECT Id FROM Account WHERE Name = 'Acme' LIMIT 1];
25
- * String fullRecordURL = URL.getOrgDomainURL().toExternalForm() + '/' + acct.Id;
26
- * ```
27
- *
28
- * @example
29
- * In this example, the base URL and the full request URL of the current Salesforce server instance are retrieved. Next, a URL
30
- * pointing to a specific account object is created. Finally, components of the base and full URL are obtained. This example
31
- * prints out all the results to the debug log output.
32
- *
33
- * ```apex
34
- * // Create a new account called Acme that we will create a link for later.
35
- * Account myAccount = new Account(Name='Acme');
36
- * insert myAccount;
37
- *
38
- * // Get the base URL.
39
- * String sfdcBaseURL = URL.getOrgDomainURL().toExternalForm();
40
- * System.debug('Base URL: ' + sfdcBaseURL );
41
- *
42
- * // Get the URL for the current request.
43
- * String currentRequestURL = URL.getCurrentRequestUrl().toExternalForm();
44
- * System.debug('Current request URL: ' + currentRequestURL);
45
- *
46
- * // Create the account URL from the base URL.
47
- * String accountURL = URL.getOrgDomainURL().toExternalForm() +
48
- * '/' + myAccount.Id;
49
- * System.debug('URL of a particular account: ' + accountURL);
50
- *
51
- * // Get some parts of the base URL.
52
- * System.debug('Host: ' + URL.getOrgDomainURL().getHost());
53
- * System.debug('Protocol: ' + URL.getOrgDomainURL().getProtocol());
54
- *
55
- * // Get the query string of the current request.
56
- * System.debug('Query: ' + URL.getCurrentRequestUrl().getQuery());
57
- * ```
58
- *
59
- * @version-behavior-changes
60
- * In API version 41.0 and later, Apex URL objects are represented by the java.net.URI type, not the java.net.URL type.
61
- * The API version in which the URL object was instantiated determines the behavior of subsequent method calls to the
62
- * specific instance. Salesforce strongly encourages you to use API 41.0 and later versions for fully RFC-compliant URL
63
- * parsing that includes proper handling of edge cases of complex URL structures. API 41.0 and later versions also enforce
64
- * that inputs are valid, RFC-compliant URL or URI strings.
65
- *
66
- * * [URL Constructors](https://developer.salesforce.com/docs/atlas.en-us.apexref.meta/apexref/apex_methods_system_url.htm#apex_System_URL_constructors)
67
- * * [URL Methods](https://developer.salesforce.com/docs/atlas.en-us.apexref.meta/apexref/apex_methods_system_url.htm#apex_System_URL_methods)
68
- *
69
- * **See Also**
70
- * * [URL Class](https://developer.salesforce.com/docs/atlas.en-us.apexcode.meta/apexcode/apex_classes_url.htm)
71
- */
72
- global class Url {
73
- /**
74
- * @description Creates a new instance of the URL class using the specified string representation of the URL.
75
- * @param spec The string to parse as a URL.
76
- */
77
- global Url(String spec) { }
78
-
79
- /**
80
- * @description Creates a new instance of the URL class by parsing the specified spec within the specified context.
81
- * @param context The context in which to parse the specification.
82
- * @param spec The string to parse as a URL.
83
- *
84
- * @usage
85
- * The new URL is created from the given context URL and the spec argument as described in RFC2396 "Uniform Resource Identifiers : Generic * Syntax" :
86
- * ```xml
87
- * <scheme>://<authority><path>?<query>#<fragment>
88
- * ```
89
- *
90
- * For more information about the arguments of this constructor, see the corresponding URL(java.net.URL, java.lang.String) constructor for Java.
91
- */
92
- global Url(Url context, String spec) { }
93
-
94
- /**
95
- * @description Creates a new instance of the URL class using the specified protocol, host, and file on the host. The default port for the specified protocol is used.
96
- * @param protocol The protocol name for this URL.
97
- * @param host The host name for this URL.
98
- * @param file The file name for this URL.
99
- */
100
- global Url(String protocol, String host, String file) {}
101
-
102
- /**
103
- * @description Creates a new instance of the URL class using the specified protocol, host, port number, and file on the host.
104
- * @param protocol The protocol name for this URL.
105
- * @param host The host name for this URL.
106
- * @param port The port number for this URL.
107
- * @param file The file name for this URL.
108
- */
109
- global Url(String protocol, String host, Integer port, String file) {}
110
-
111
- /**
112
- * @description Returns the authority portion of the current URL.
113
- * @return The authority portion of the current URL.
114
- */
115
- global String getAuthority() {
116
- return null;
117
- }
118
-
119
- /**
120
- * @description Returns the URL of an entire request on a Salesforce instance.
121
- * @return The URL of the entire request.
122
- * @usage An example of a URL for an entire request is https://yourInstance.salesforce.com/apex/myVfPage.apexp.
123
- */
124
- global static Url getCurrentRequestUrl() {
125
- return null;
126
- }
127
-
128
- /**
129
- * @description Returns the default port number of the protocol associated with the current URL.
130
- * @return The default port number of the protocol associated with the current URL.
131
- * @usage Returns -1 if the URL scheme or the stream protocol handler for the URL doesn't define a default port number.
132
- */
133
- global Integer getDefPort() {
134
- return null;
135
- }
136
-
137
- /**
138
- * @description Returns the file name of the current URL.
139
- * @return The file name of the current URL.
140
- */
141
- global String getFile() {
142
- return null;
143
- }
144
-
145
- /**
146
- * @description Returns the download URL for a file attachment.
147
- * @param entityId Specifies the ID of the entity that holds the file data.
148
- * @param fieldName Specifies the API name of a file field component, such as `AttachmentBody`.
149
- * @return The download URL for the file attachment.
150
- * @example
151
- * String fileURL =
152
- * URL.getFileFieldURL(
153
- * '087000000000123' ,
154
- * 'AttachmentBody');
155
- */
156
- global static String getFileFieldURL(String entityId, String fieldName) {
157
- return null;
158
- }
159
-
160
- /**
161
- * @description Returns the host name of the current URL.
162
- * @return The host name of the current URL.
163
- */
164
- global String getHost() {
165
- return null;
166
- }
167
-
168
- /**
169
- * @description Returns the canonical URL for your org. For example, https://MyDomainName.my.salesforce.com.
170
- * @return getOrgDomainUrl() always returns the login URL for your org, regardless of context. Use that URL when making API calls to your org.
171
- * @usage
172
- * Use getOrgDomainUrl() to interact with Salesforce REST and SOAP APIs in Apex code. Get endpoints for User Interface API calls, for creating and customizing picklist value sets and custom fields, and more.
173
- *
174
- * `getOrgDomainUrl()` can access the domain URL only for the org in which the Apex code is running.
175
- *
176
- * You don't need a RemoteSiteSetting for your org to interact with the Salesforce APIs using domain URLs retrieved with this method.
177
- *
178
- * @example
179
- * This example uses the Salesforce REST API to get organization limit values. For information on limits, see Limits in the REST API Developer Guide.
180
- * ```apex
181
- * Http h = new Http();
182
- * HttpRequest req = new HttpRequest();
183
- * req.setEndpoint(Url.getOrgDomainUrl().toExternalForm()
184
- * + '/services/data/v44.0/limits');
185
- * req.setMethod('GET');
186
- * req.setHeader('Authorization', 'Bearer ' + UserInfo.getSessionId());
187
- * HttpResponse res = h.send(req);
188
- * ```
189
- *
190
- * @see-also
191
- * * [Lightning Aura Components Developer Guide: Making API Calls from Apex](https://developer.salesforce.com/docs/atlas.en-us.250.0.lightning.meta/lightning/apex_api_calls.htm)
192
- */
193
- global static Url getOrgDomainUrl() {
194
- return null;
195
- }
196
- }