You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

CoreActionComponent.java 19KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800
  1. /*
  2. * Copyright (c) 2006-2014 DMDirc Developers
  3. *
  4. * Permission is hereby granted, free of charge, to any person obtaining a copy
  5. * of this software and associated documentation files (the "Software"), to deal
  6. * in the Software without restriction, including without limitation the rights
  7. * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
  8. * copies of the Software, and to permit persons to whom the Software is
  9. * furnished to do so, subject to the following conditions:
  10. *
  11. * The above copyright notice and this permission notice shall be included in
  12. * all copies or substantial portions of the Software.
  13. *
  14. * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  15. * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
  16. * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
  17. * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
  18. * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
  19. * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
  20. * SOFTWARE.
  21. */
  22. package com.dmdirc.actions;
  23. import com.dmdirc.Channel;
  24. import com.dmdirc.FrameContainer;
  25. import com.dmdirc.Query;
  26. import com.dmdirc.interfaces.Connection;
  27. import com.dmdirc.interfaces.actions.ActionComponent;
  28. import com.dmdirc.interfaces.config.ConfigProvider;
  29. import com.dmdirc.interfaces.ui.Window;
  30. import com.dmdirc.logger.ErrorLevel;
  31. import com.dmdirc.logger.Logger;
  32. import com.dmdirc.parser.interfaces.ChannelClientInfo;
  33. import com.dmdirc.parser.interfaces.ClientInfo;
  34. import com.dmdirc.util.colours.Colour;
  35. import com.dmdirc.ui.messages.Styliser;
  36. import java.awt.event.KeyEvent;
  37. import java.util.Calendar;
  38. import java.util.GregorianCalendar;
  39. import javax.swing.KeyStroke;
  40. /**
  41. * A CoreActionComponent represents a component of some object that the user can use as the subject
  42. * of a condition within an action.
  43. */
  44. public enum CoreActionComponent implements ActionComponent {
  45. /** Returns the name of the server. */
  46. SERVER_NAME {
  47. @Override
  48. public Object get(final Object arg) {
  49. return ((Connection) arg).getAddress();
  50. }
  51. @Override
  52. public Class<?> appliesTo() {
  53. return Connection.class;
  54. }
  55. @Override
  56. public Class<?> getType() {
  57. return String.class;
  58. }
  59. @Override
  60. public String getName() {
  61. return "name";
  62. }
  63. },
  64. /** Returns the network of the server. */
  65. SERVER_NETWORK {
  66. @Override
  67. @ComponentOptions(requireConnected = true)
  68. public Object get(final Object arg) {
  69. return ((Connection) arg).getNetwork();
  70. }
  71. @Override
  72. public Class<?> appliesTo() {
  73. return Connection.class;
  74. }
  75. @Override
  76. public Class<?> getType() {
  77. return String.class;
  78. }
  79. @Override
  80. public String getName() {
  81. return "network";
  82. }
  83. },
  84. /**
  85. * Returns the protocol of the server.
  86. *
  87. * @since 0.6.4
  88. */
  89. SERVER_PROTOCOL {
  90. @Override
  91. public Object get(final Object arg) {
  92. return ((Connection) arg).getProtocol();
  93. }
  94. @Override
  95. public Class<?> appliesTo() {
  96. return Connection.class;
  97. }
  98. @Override
  99. public Class<?> getType() {
  100. return String.class;
  101. }
  102. @Override
  103. public String getName() {
  104. return "protocol";
  105. }
  106. },
  107. /** Returns the away reason for the server. */
  108. SERVER_MYAWAYREASON {
  109. @Override
  110. public Object get(final Object arg) {
  111. return ((Connection) arg).getAwayMessage();
  112. }
  113. @Override
  114. public Class<?> appliesTo() {
  115. return Connection.class;
  116. }
  117. @Override
  118. public Class<?> getType() {
  119. return String.class;
  120. }
  121. @Override
  122. public String getName() {
  123. return "away reason";
  124. }
  125. },
  126. /** Returns the channel umodes for the server. */
  127. SERVER_CHANNELUMODES {
  128. @Override
  129. @ComponentOptions(requireConnected = true)
  130. public Object get(final Object arg) {
  131. return ((Connection) arg).getParser().getChannelUserModes();
  132. }
  133. @Override
  134. public Class<?> appliesTo() {
  135. return Connection.class;
  136. }
  137. @Override
  138. public Class<?> getType() {
  139. return String.class;
  140. }
  141. @Override
  142. public String getName() {
  143. return "list of channel usermodes";
  144. }
  145. },
  146. /** Returns the nickname for the server. */
  147. SERVER_MYNICKNAME {
  148. @Override
  149. @ComponentOptions(requireConnected = true)
  150. public Object get(final Object arg) {
  151. final Connection server = (Connection) arg;
  152. if (server == null || server.getParser() == null) {
  153. Logger.appError(ErrorLevel.LOW, "SERVER_MYNICKNAME.get() called with null element",
  154. new UnsupportedOperationException(server == null ? "Server was null" :
  155. server.getParser() == null ? "Parser was null" : "Unknown"));
  156. return "null";
  157. } else {
  158. return server.getParser().getLocalClient().getNickname();
  159. }
  160. }
  161. @Override
  162. public Class<?> appliesTo() {
  163. return Connection.class;
  164. }
  165. @Override
  166. public Class<?> getType() {
  167. return String.class;
  168. }
  169. @Override
  170. public String getName() {
  171. return "nickname";
  172. }
  173. },
  174. /** Returns the name of the server. */
  175. SERVER_PROFILE {
  176. @Override
  177. public Object get(final Object arg) {
  178. return ((Connection) arg).getProfile();
  179. }
  180. @Override
  181. public Class<?> appliesTo() {
  182. return Connection.class;
  183. }
  184. @Override
  185. public Class<?> getType() {
  186. return ConfigProvider.class;
  187. }
  188. @Override
  189. public String getName() {
  190. return "profile";
  191. }
  192. },
  193. /** Returns the name of the channel. */
  194. CHANNEL_NAME {
  195. @Override
  196. public Object get(final Object arg) {
  197. return ((Channel) arg).getChannelInfo().getName();
  198. }
  199. @Override
  200. public Class<?> appliesTo() {
  201. return Channel.class;
  202. }
  203. @Override
  204. public Class<?> getType() {
  205. return String.class;
  206. }
  207. @Override
  208. public String getName() {
  209. return "name";
  210. }
  211. },
  212. /**
  213. * Returns the notification colour of the channel.
  214. */
  215. CHANNEL_COLOUR {
  216. @Override
  217. public Object get(final Object arg) {
  218. // TODO: This should understand unset notifications
  219. return ((Channel) arg).getNotification().or(Colour.BLACK);
  220. }
  221. @Override
  222. public Class<?> appliesTo() {
  223. return Channel.class;
  224. }
  225. @Override
  226. public Class<?> getType() {
  227. return Colour.class;
  228. }
  229. @Override
  230. public String getName() {
  231. return "notification colour";
  232. }
  233. },
  234. /** Returns the name of a client. */
  235. CLIENT_NAME {
  236. @Override
  237. public Object get(final Object arg) {
  238. return ((ClientInfo) arg).getNickname();
  239. }
  240. @Override
  241. public Class<?> appliesTo() {
  242. return ClientInfo.class;
  243. }
  244. @Override
  245. public Class<?> getType() {
  246. return String.class;
  247. }
  248. @Override
  249. public String getName() {
  250. return "nickname";
  251. }
  252. },
  253. /** Returns the host of a client. */
  254. CLIENT_HOST {
  255. @Override
  256. public Object get(final Object arg) {
  257. return ((ClientInfo) arg).getHostname();
  258. }
  259. @Override
  260. public Class<?> appliesTo() {
  261. return ClientInfo.class;
  262. }
  263. @Override
  264. public Class<?> getType() {
  265. return String.class;
  266. }
  267. @Override
  268. public String getName() {
  269. return "host";
  270. }
  271. },
  272. /** Returns the name of a client. */
  273. USER_NAME {
  274. @Override
  275. public Object get(final Object arg) {
  276. return ((ChannelClientInfo) arg).getClient().getNickname();
  277. }
  278. @Override
  279. public Class<?> appliesTo() {
  280. return ChannelClientInfo.class;
  281. }
  282. @Override
  283. public Class<?> getType() {
  284. return String.class;
  285. }
  286. @Override
  287. public String getName() {
  288. return "nickname";
  289. }
  290. },
  291. /** Returns the modes of a client. */
  292. USER_MODES {
  293. @Override
  294. public Object get(final Object arg) {
  295. return ((ChannelClientInfo) arg).getAllModes();
  296. }
  297. @Override
  298. public Class<?> appliesTo() {
  299. return ChannelClientInfo.class;
  300. }
  301. @Override
  302. public Class<?> getType() {
  303. return String.class;
  304. }
  305. @Override
  306. public String getName() {
  307. return "modes";
  308. }
  309. },
  310. /** Returns the host of a client. */
  311. USER_HOST {
  312. @Override
  313. public Object get(final Object arg) {
  314. return ((ChannelClientInfo) arg).getClient().getHostname();
  315. }
  316. @Override
  317. public Class<?> appliesTo() {
  318. return ChannelClientInfo.class;
  319. }
  320. @Override
  321. public Class<?> getType() {
  322. return String.class;
  323. }
  324. @Override
  325. public String getName() {
  326. return "host";
  327. }
  328. },
  329. /**
  330. * Returns the number of common channels the client is on.
  331. */
  332. USER_COMCHANS {
  333. @Override
  334. public Object get(final Object arg) {
  335. return ((ChannelClientInfo) arg).getClient().getChannelCount();
  336. }
  337. @Override
  338. public Class<?> appliesTo() {
  339. return ChannelClientInfo.class;
  340. }
  341. @Override
  342. public Class<?> getType() {
  343. return Integer.class;
  344. }
  345. @Override
  346. public String getName() {
  347. return "number of common channels";
  348. }
  349. },
  350. /** Returns the content of a string. */
  351. STRING_STRING {
  352. @Override
  353. public Object get(final Object arg) {
  354. return arg;
  355. }
  356. @Override
  357. public Class<?> appliesTo() {
  358. return String.class;
  359. }
  360. @Override
  361. public Class<?> getType() {
  362. return String.class;
  363. }
  364. @Override
  365. public String getName() {
  366. return "content";
  367. }
  368. },
  369. /**
  370. * Returns the content of a string, stripped of formatting.
  371. */
  372. STRING_STRIPPED {
  373. @Override
  374. public Object get(final Object arg) {
  375. return Styliser.stipControlCodes((String) arg);
  376. }
  377. @Override
  378. public Class<?> appliesTo() {
  379. return String.class;
  380. }
  381. @Override
  382. public Class<?> getType() {
  383. return String.class;
  384. }
  385. @Override
  386. public String getName() {
  387. return "content (without formatting)";
  388. }
  389. },
  390. /** Returns the length of a string. */
  391. STRING_LENGTH {
  392. @Override
  393. public Object get(final Object arg) {
  394. return ((String) arg).length();
  395. }
  396. @Override
  397. public Class<?> appliesTo() {
  398. return String.class;
  399. }
  400. @Override
  401. public Class<?> getType() {
  402. return Integer.class;
  403. }
  404. @Override
  405. public String getName() {
  406. return "length";
  407. }
  408. },
  409. /** Returns the size of a string array. */
  410. STRINGARRAY_LENGTH {
  411. @Override
  412. public Object get(final Object arg) {
  413. return ((String[]) arg).length;
  414. }
  415. @Override
  416. public Class<?> appliesTo() {
  417. return String[].class;
  418. }
  419. @Override
  420. public Class<?> getType() {
  421. return Integer.class;
  422. }
  423. @Override
  424. public String getName() {
  425. return "size";
  426. }
  427. },
  428. /**
  429. * Returns the readable representation of a date.
  430. */
  431. CALENDAR_FULLSTRING {
  432. @Override
  433. public Object get(final Object arg) {
  434. return ((GregorianCalendar) arg).getTime().toString();
  435. }
  436. @Override
  437. public Class<?> appliesTo() {
  438. return Calendar.class;
  439. }
  440. @Override
  441. public Class<?> getType() {
  442. return String.class;
  443. }
  444. @Override
  445. public String getName() {
  446. return "full date";
  447. }
  448. },
  449. /**
  450. * Returns the name of the key that was pressed.
  451. */
  452. KEYEVENT_KEYNAME {
  453. @Override
  454. public Object get(final Object arg) {
  455. return KeyEvent.getKeyText(((KeyStroke) arg).getKeyCode());
  456. }
  457. @Override
  458. public Class<?> appliesTo() {
  459. return KeyStroke.class;
  460. }
  461. @Override
  462. public Class<?> getType() {
  463. return String.class;
  464. }
  465. @Override
  466. public String getName() {
  467. return "key name";
  468. }
  469. },
  470. /**
  471. * Returns the state of the control key for a key press event.
  472. */
  473. KEYEVENT_CTRLSTATE {
  474. @Override
  475. public Object get(final Object arg) {
  476. return (((KeyStroke) arg).getModifiers() & KeyEvent.CTRL_DOWN_MASK) != 0;
  477. }
  478. @Override
  479. public Class<?> appliesTo() {
  480. return KeyStroke.class;
  481. }
  482. @Override
  483. public Class<?> getType() {
  484. return Boolean.class;
  485. }
  486. @Override
  487. public String getName() {
  488. return "control key state";
  489. }
  490. },
  491. /**
  492. * Returns the state of the shift key for a key press event.
  493. */
  494. KEYEVENT_SHIFTSTATE {
  495. @Override
  496. public Object get(final Object arg) {
  497. return (((KeyStroke) arg).getModifiers() & KeyEvent.SHIFT_DOWN_MASK) != 0;
  498. }
  499. @Override
  500. public Class<?> appliesTo() {
  501. return KeyStroke.class;
  502. }
  503. @Override
  504. public Class<?> getType() {
  505. return Boolean.class;
  506. }
  507. @Override
  508. public String getName() {
  509. return "shift key state";
  510. }
  511. },
  512. /**
  513. * Returns the state of the shift key for a key press event.
  514. */
  515. KEYEVENT_ALTSTATE {
  516. @Override
  517. public Object get(final Object arg) {
  518. return (((KeyStroke) arg).getModifiers() & KeyEvent.ALT_DOWN_MASK) != 0;
  519. }
  520. @Override
  521. public Class<?> appliesTo() {
  522. return KeyStroke.class;
  523. }
  524. @Override
  525. public Class<?> getType() {
  526. return Boolean.class;
  527. }
  528. @Override
  529. public String getName() {
  530. return "alt key state";
  531. }
  532. },
  533. /** Returns the host of the query. */
  534. QUERY_HOST {
  535. @Override
  536. public Object get(final Object arg) {
  537. return ((Query) arg).getHost();
  538. }
  539. @Override
  540. public Class<?> appliesTo() {
  541. return Query.class;
  542. }
  543. @Override
  544. public Class<?> getType() {
  545. return String.class;
  546. }
  547. @Override
  548. public String getName() {
  549. return "host";
  550. }
  551. },
  552. /** Returns the host of the query. */
  553. QUERY_NICK {
  554. @Override
  555. public Object get(final Object arg) {
  556. return ((Query) arg).getName();
  557. }
  558. @Override
  559. public Class<?> appliesTo() {
  560. return Query.class;
  561. }
  562. @Override
  563. public Class<?> getType() {
  564. return String.class;
  565. }
  566. @Override
  567. public String getName() {
  568. return "nick";
  569. }
  570. },
  571. /**
  572. * Returns the notification colour of the query.
  573. */
  574. QUERY_COLOUR {
  575. @Override
  576. public Object get(final Object arg) {
  577. // TODO: This should understand unset notifications
  578. return ((Query) arg).getNotification().or(Colour.BLACK);
  579. }
  580. @Override
  581. public Class<?> appliesTo() {
  582. return Query.class;
  583. }
  584. @Override
  585. public Class<?> getType() {
  586. return Colour.class;
  587. }
  588. @Override
  589. public String getName() {
  590. return "notification colour";
  591. }
  592. },
  593. /** The name of a window. */
  594. WINDOW_NAME {
  595. @Override
  596. public Object get(final Object arg) {
  597. return ((FrameContainer) arg).getName();
  598. }
  599. @Override
  600. public Class<?> appliesTo() {
  601. return FrameContainer.class;
  602. }
  603. @Override
  604. public Class<?> getType() {
  605. return String.class;
  606. }
  607. @Override
  608. public String getName() {
  609. return "name";
  610. }
  611. },
  612. /**
  613. * Returns the notification colour of the window.
  614. */
  615. WINDOW_COLOUR {
  616. @Override
  617. public Object get(final Object arg) {
  618. // TODO: This should understand unset notifications
  619. return ((FrameContainer) arg).getNotification().or(Colour.BLACK);
  620. }
  621. @Override
  622. public Class<?> appliesTo() {
  623. return FrameContainer.class;
  624. }
  625. @Override
  626. public Class<?> getType() {
  627. return Colour.class;
  628. }
  629. @Override
  630. public String getName() {
  631. return "notification colour";
  632. }
  633. },
  634. /**
  635. * Returns the server of the window.
  636. *
  637. * @since 0.6.4
  638. */
  639. WINDOW_SERVER {
  640. @Override
  641. public Object get(final Object arg) {
  642. return ((Window) arg).getContainer().getConnection();
  643. }
  644. @Override
  645. public Class<?> appliesTo() {
  646. return Window.class;
  647. }
  648. @Override
  649. public Class<?> getType() {
  650. return Connection.class;
  651. }
  652. @Override
  653. public String getName() {
  654. return "server";
  655. }
  656. },
  657. /** Returns the name of an identity. */
  658. IDENTITY_NAME {
  659. @Override
  660. public Object get(final Object arg) {
  661. return ((ConfigProvider) arg).getName();
  662. }
  663. @Override
  664. public Class<?> appliesTo() {
  665. return ConfigProvider.class;
  666. }
  667. @Override
  668. public Class<?> getType() {
  669. return String.class;
  670. }
  671. @Override
  672. public String getName() {
  673. return "name";
  674. }
  675. },
  676. /** Returns the value of an integer. */
  677. INTEGER_VALUE {
  678. @Override
  679. public Object get(final Object arg) {
  680. return arg;
  681. }
  682. @Override
  683. public Class<?> appliesTo() {
  684. return Integer.class;
  685. }
  686. @Override
  687. public Class<?> getType() {
  688. return Integer.class;
  689. }
  690. @Override
  691. public String getName() {
  692. return "value";
  693. }
  694. }
  695. }