| 1 | = InterTrac Links = |
| 2 | |
| 3 | Trac supports a convenient way to refer to resources of other Trac servers, from within the Wiki markup, since version 0.10. |
| 4 | |
| 5 | == Definitions == |
| 6 | |
| 7 | An InterTrac link can be seen as a scoped TracLinks. |
| 8 | It is used for referring to a Trac resource |
| 9 | (Wiki page, changeset, ticket, ...) located in another |
| 10 | Trac environment. |
| 11 | |
| 12 | == List of Active InterTrac Prefixes == |
| 13 | |
| 14 | [[InterTrac]] |
| 15 | |
| 16 | == Link Syntax == |
| 17 | |
| 18 | Simply use the name of the other Trac environment as a prefix, |
| 19 | followed by a colon, ending with the resource located in the other environment. |
| 20 | |
| 21 | {{{ |
| 22 | <target_environment>:<TracLinks> |
| 23 | }}} |
| 24 | |
| 25 | The other resource is specified using a regular TracLinks, of any flavor. |
| 26 | |
| 27 | That target environment name is either the real name of the |
| 28 | environment, or an alias for it. |
| 29 | The aliases are defined in `trac.ini` (see below). |
| 30 | The prefix is case insensitive. |
| 31 | |
| 32 | When a TracLink is enclosed in brackets, the alias is expanded. That is, `[th:ticket:1]` is displayed as `trachacks:ticket:1`, since `th` is an alias for `trachacks`. If the TracLink is not enclosed in brackets, then the alias is displayed as it is typed. |
| 33 | |
| 34 | For convenience, there's also some alternative short-hand form, |
| 35 | where one can use an alias as an immediate prefix |
| 36 | for the identifier of a ticket, changeset or report: |
| 37 | (e.g. `#T234`, `[T1508]`, `[trac 1508]`, ...) |
| 38 | |
| 39 | == Examples == |
| 40 | |
| 41 | It is necessary to setup a configuration for the InterTrac facility. |
| 42 | This configuration has to be done in the TracIni file, `[intertrac]` section. |
| 43 | |
| 44 | Example configuration: |
| 45 | {{{ |
| 46 | ... |
| 47 | [intertrac] |
| 48 | # -- Example of setting up an alias: |
| 49 | t = trac |
| 50 | |
| 51 | # -- Link to an external Trac: |
| 52 | trac.title = Edgewall's Trac for Trac |
| 53 | trac.url = http://trac.edgewall.org |
| 54 | }}} |
| 55 | |
| 56 | The `.url` is mandatory and is used for locating the other Trac. |
| 57 | This can be a relative URL in case that Trac environment is located |
| 58 | on the same server. |
| 59 | |
| 60 | The `.title` information will be used for providing an useful tooltip |
| 61 | when moving the cursor over an InterTrac links. |
| 62 | |
| 63 | Finally, the `.compat` option can be used to activate or disable |
| 64 | a ''compatibility'' mode: |
| 65 | * If the targeted Trac is running a version below [trac:milestone:0.10 0.10] |
| 66 | ([trac:r3526 r3526] to be precise), then it doesn't know how to dispatch an InterTrac |
| 67 | link, and it's up to the local Trac to prepare the correct link. |
| 68 | Not all links will work that way, but the most common do. |
| 69 | This is called the compatibility mode, and is `true` by default. |
| 70 | * If you know that the remote Trac knows how to dispatch InterTrac links, |
| 71 | you can explicitly disable this compatibility mode and then ''any'' |
| 72 | TracLinks can become an InterTrac link. |
| 73 | |
| 74 | Now, given the above configuration, one could create the following links: |
| 75 | * to this InterTrac page: |
| 76 | * `trac:wiki:InterTrac` trac:wiki:InterTrac |
| 77 | * `t:wiki:InterTrac` t:wiki:InterTrac |
| 78 | * Keys are case insensitive: `T:wiki:InterTrac` T:wiki:InterTrac |
| 79 | * to the ticket #234: |
| 80 | * `trac:ticket:234` trac:ticket:234 |
| 81 | * `trac:#234` trac:#234 |
| 82 | * `#T234` #T234 |
| 83 | * to the changeset [1912]: |
| 84 | * `trac:changeset:1912` trac:changeset:1912 |
| 85 | * `[T1912]` [T1912] |
| 86 | * to the log range [3300:3330]: '''(Note: the following ones need `trac.compat=false`)''' |
| 87 | * `trac:log:@3300:3330` trac:log:@3300:3330 |
| 88 | * `[trac 3300:3330]` [trac 3300:3330] |
| 89 | * finally, to link to the start page of a remote trac, simply use its prefix followed by ':', inside an explicit link. Example: `[th: Trac Hacks]` (''since 0.11; note that the ''remote'' Trac has to run 0.11 for this to work'') |
| 90 | |
| 91 | The generic form `intertrac_prefix:module:id` is translated |
| 92 | to the corresponding URL `<remote>/module/id`, shorthand links |
| 93 | are specific to some modules (e.g. !#T234 is processed by the |
| 94 | ticket module) and for the rest (`intertrac_prefix:something`), |
| 95 | we rely on the TracSearch#quickjump facility of the remote Trac. |
| 96 | |
| 97 | ---- |
| 98 | See also: TracLinks, InterWiki |